rooms and version # 48KRA-1 "Dynamic Read/Write Memory Module User's Manual Processor Technology Corporation 7100 Johnson Industrial Drive Pleasanton, CA 94566 Telephone (415) 829-2600 Copyright © 1978, by Processor Technology Corporation First Edition, First Printing, July, 1978 Manual Part No. 730027 All rights reserved. # **CAUTION** Please read Section 2, Handling Precautions and Unpacking, before unpacking or handling your 48KRA-1 any further. # **CONTENTS** | SECTION | | | | PAGE | |---------|-------------|-------------------------|-------------------------------------------------------------------|--------------------| | 1 | INTRO | ODUCTION | N AND GENERAL INFORMATION | | | | 1.1 | INTROD | UCTION | 1-1 | | | 1.2 | GENERA | AL INFORMATION | 1-1 | | | 1.3 | SPECIFI | CATIONS | 1-1 | | 2 | HANE | DLING PRE | CAUTIONS AND UNPACKING | | | | 2.1 | HANDLI | NG PRECAUTIONS | 2-1 | | | 2.2 | UNPAC | KING INSPECTION | 2-2 | | 3 | SETU | IP AND INS | STALLATION | | | | 3.1 | MEMOR | Y DISABLE OPTION | 3-1 | | | 3.2 | SETTING | G STARTING ADDRESSES | 3-1 | | | | 3.2.1<br>3.2.2 | Before Setting Switches | 3-1<br>3-1 | | | 3.3 | | LATION | 3-3 | | | 3.4 | EXTEND | DED ADDRESSING AND 16-BIT DATA WORD OPTIONS | 3-4 | | | | | | | | 4 | MEM:<br>4.1 | ORY TEST | EFORE OPERATING | 4-1 | | | | | | | | | 4.2 | THE RE | COMMENDED PRE-OPERATING MEMORY TEST | 4-1<br>4-1 | | | 4.3 | | Test Procedure (Long Memory Test) MEMORY TEST | | | _ | TUE | | DEDATION | | | 5 | 5.1 | | PERATION<br>EW | 5-1 | | | 5.1 | 5.1.1 | S-100 Bus Interface | • | | | | 5.1.2 | Memory Array | 5-1 | | | | 5.1.3<br>5.1.4 | Manufacturing Options | | | | | 5.1.4 | Addressing | 5-2 | | | | 5.1.6 | Write and Read Operations | 5-2 | | | 5.2 | PAGE S | ELECTION | 5-2 | | | 5.3 | MEMOR | Y CYCLES | 5-3 | | | | 5.3.1<br>5.3.2 | Timing Scheme Enables Independent Refresh Timing of Memory Cycles | 5-3<br>5-3 | | | | 5.3.3 | Types of Memory Cycles | 5-5 | | | 5.4 | OPERA <sup>2</sup> | FIONS: The State Machine | 5-6 | | | | 5.4.1 | Variations of the Six Operations | 5-6 | | | 5.5 | | STS FOR MEMORY OPERATIONS | 5-9 | | | | 5.5.1<br>5.5.2<br>5.5.3 | Normal Access, Selected | 5-9<br>5-9<br>5-10 | | | 5.6 | EXTENDED ADDRESSING | 5-12 | |---|--------|---------------------------------------------------------------|------| | | | 5.6.1 Types of Extended Addressing | | | | | Extended Selection Logic | 5-12 | | | | Extended Selection Logic | | | | 5.7 | MODIFICATION FOR 16-BIT DATA WORDS | 5-14 | | 6 | MAIN | TENANCE AND DIAGNOSTICS | | | | 6.1 | SERVICE | 6-1 | | | 6.2 | REPLACEMENT PARTS | 6-1 | | | 6.3 | TROUBLESHOOTING AND DIAGNOSTIC TEST PROGRAMS | 6-1 | | | 6.4 | HARDWARE TROUBLESHOOTING | 6-1 | | 7 | DRAW | VINGS | | | | Fig. 7 | -1. 48KRA-1 System Block Diagram | | | | Fig. 7 | -2. 48KRA-1 Schematic, Sheet 1 | | | | Fig. 7 | -3. 48KRA-1 Schematic, Sheet 2 | | | | Fig. 7 | -4. 48KRA-1 Assembly | | | | Fig. 7 | -5. 48KRA-1 PCB Traces | | | | | APPENDICES | | | | | 1 LONG MEMORY TEST PROGRAM, Listing | | | | | 2 SHORT MEMORY TEST PROGRAM, Listing | | | | | 3 IC PIN CONFIGURATIONS | | | | | TABLES | | | | 3-1 | 48KRA-1 ADDRESS SWITCH SELECTION | 3-2 | | | 5-1 | THE NINE STATES OF THE STATE MACHINE | 5-8 | | | 5-2 | S-100 BUS SIGNALS OF THE 48KRA-1 MEMORY MODULE | 5-16 | | | 5-3 | INTERNAL SIGNALS OF THE 48KRA-1 MEMORY MODULE | 5-17 | | | 7-1 | KEY TO SYSTEM BLOCK DIAGRAM | 7-2 | | | | FIGURES | | | | 3-1 | Page and Address Assignments for 48KRA-1 Selection Switches . | 3-2 | | | 4-1 | Page and Bit Assignments in Memory Array | 4-2 | | | 5-1 | Timing of Typical Read Cycle | 5-4 | | | 5-2 | Sequences of the Operation Request Logic | 5-7 | | | 5-3 | States of the Synchronous Counter Producing DEPOSIT | 5-11 | | | | | | # INTRODUCTION AND GENERAL INFORMATION ### 1.1 INTRODUCTION This manual supplies the information needed to test, use and maintain the 48KRA-1 Dynamic Read/Write Memory Module. In order that you might use your module most effectively and safely, we suggest that you read the entire manual before attempting to use the memory module. ### 1.2 GENERAL INFORMATION The 48KRA-1 has a capacity of 49,152 8-bit words (bytes), stored in 24 16K-bit RAMs (Random Access Memories). The 48KRA-1 operates in a dynamic mode. Periodic refreshing is done automatically by the module. The 48KRA-1 is designed to operate in the Sol S-100 bus and a number of other 8080-based computers which have a 2 MHz PHASE 2 rate without imposing *wait* states. Lines interfacing the S-100 bus are fully buffered. Address allocation is switch selectable. The 48KRA-1 is organized into three pages of 16,384 bytes each. Each page may be independently assigned to any of 16 starting addresses at 4096-byte intervals, starting with address 0000 (hexadecimal). If the starting address is D000, E000, or F000, that part of the page which would fall beyond FFFF is assigned to memory space in the range 0000-2FFF. (Refer to Table 3-1, 48KRA-1 Address Switch Selection.) A wide variety of extended addressing schemes are available as user options. Modifications for 16-bit data words can also be made by the user. ### 1.3 SPECIFICATIONS The 48KRA-1 Memory requires the following ranges of unregulated DC supply: +7.5 to +10 VDC at 1.20 A max +15 to +18 VDC at 0.20 A max -15 to -18 VDC at 0.02 A max Access time is 460 ns; cycle time is 489 ns min. Memory IC technology: MOS (Metal Oxide Semiconductor). # HANDLING PRECAUTIONS AND UNPACKING ### 2.1 HANDLING PRECAUTIONS Your memory module and its components are delicate electronic devices. If the following precautions are not observed, they could be damaged during handling, installation, removal, trouble-shooting, or component replacement. - 1) Before installing or removing the memory module, turn the computer power OFF. To remove or install it with computer power on can damage the module or the computer. - 2) Before installing or removing ICs, turn OFF power to the memory module. To remove or install them with power on can damage the ICs. - 3) The memory ICs used on the memory module are MOS devices. MOS (Metal Oxide Semiconductor) devices are constructed with a very thin insulating layer of silicon dioxide (glass) separating the metal gate from the substrate. This layer can be punctured by electric fields, such as static electricity, as small as 100 V carrying only 10 pA. To avoid any possible static electricity discharge damage to the MOS elements, always take care to handle the memory module or its MOS ICs in such a way that no discharge flows through them from your body or from tools. - a. When installing or removing the memory module or its MOS ICs, before touching the module with one hand, always place the other hand on the computer chassis first to discharge static. - b. When grasping the module, grasp it by its edge-connector or the bus traces around its perimeter. - c. Avoid unnecessary handling of the module and the ICs. When handling the MOS ICs, wear cotton clothing (rather than synthetic). Be sure to discharge your body static field before touching the MOS ICs. All ICs other than the memory ICs and U43 are Schottky TTL and low power Schottky TTL. These do not require precautions against static electricity. # 4) Ground Test Point Connections Attach ground clip leads only on the test point (wire loop) installed for this purpose at pin 50 in the lower right corner of the component side of the module. (Refer to Fig 7-4, 48KRA-1 Assembly.) Do not attach clip leads to the ground or power buses around the perimeter of the board. Such connections are liable to short to IC pins. ### **CAUTION** The heatsink is a poor ground because its finish is nonconducting. Do not attach clip leads to the heatsink. ### 5) Manufacturing Options A1 is a special configuration module which is varied by the factory according to the memory ICs used in a given production run. Do not interchange or mix the configuration modules of your 48KRA-1 with those of any other memory module which contains a different make and/or type of memory IC. ### 2.2 UNPACKING INSPECTION - 1) Examine the shipping container for signs of possible damage to the contents during transit. - 2) READ SECTION 2.1, HANDLING PRECAUTIONS, CAREFULLY. - 3) Carefully open the container and withdraw the memory module. Do *not* sink a knife blade deep within the container. - 4) Save the shipping materials for possible use in returning the module to your dealer, and in case the dealer needs to ship it to the factory. - 5) Visually inspect the module for obvious physical damage. Check that all integrated circuits (ICs) are fully seated in their sockets. - 6) If your 48KRA-1 is damaged, please contact the carrier and your dealer immediately, describing the condition of both the shipping container and its contents so that they can take appropriate action. # SETUP AND INSTALLATION ### 3.1 MEMORY DISABLE OPTION The 48KRA-1 comes with the memory disable option (PHANTOM) installed in the form of a jumper wire between pads E and F. It is recommended that you retain this option which allows the memory module, at address Ø, to be disabled by the signal PHANTOM which is supplied on S-I00 bus pin 67 by the Sol computer and Processor Technology firmware modules such as ALS8 and GPM. PHANTOM is also produced by various other S-100 subsystems available from microcomputer vendors. If necessary, PHANTOM can be disabled by snipping off the jumper between E and F. E and F are located below the configuration module A1. (Refer to Fig. 7-4, 48KRA-1 Assembly.) ### 3.2 SETTING STARTING ADDRESSES ### 3.2.1 Before Setting Switches Each of the four pages can be independently allocated with the DIP (Dual Inline Package) switches located near the upper right edge of the module. (Refer to Fig 7-4, 48KRA-1 Assembly.) Page and address assignments for these switches are shown in Figure 3-1, Page and Address Assignments for 48KRA-1 Selection Switches. You may assign the same starting address to two, or all three pages on *one* module with no ill effect. In general, you may *not* assign to a module any memory space that is already assigned to another module if they are to share the same bus simultaneously. To do so will cause the bus drivers to contend for possession of <u>the bus</u> resulting improper operation or damage. (One exception to this general rule is if the PHANTOM memory disable option is installed. This option allows the ALS8 to share address zero with a 48KRA-1.) Another exception is bank select or extended addressing. See section 5.6 on extended addressing. ### 3.2.2 Instructions for Setting Switches Since the DIP switches are located on the top edge of the memory module, they are accessible after the module is installed in the S-100 backplane; however, to avoid removing the cover of the computer unnecessarily, it is recommended that you set the address switches before installing the module. 1) To select the desired starting address for a page, refer to Table 3-1, 48KRA-1 Address Switch Selection. 1K= 1024 bytes (20) Table 3-1. 48KRA-1 Address Switch Selection | | STARTING | ADDRESS | ENDING A | DDRESS | DII | SWITCH | H SETTING | as . | |-----|----------|---------|----------|--------|------|--------|-----------|------| | | Decimal | Hex | Decimal | Hex | A 15 | A 14 | A 13 | A 12 | | OK | 0 | 0000 | 16,383 | 3FFF | 0 | 0 | 0 | 0 | | | 4,096 | 1000 | 20,479 | 4FFF | 0 | 0 | 0 | 1 | | | 8,192 | 2000 | 24,575 | 5FFF | 0 | 0 | 1 | 0 | | | 12,288 | 3000 | 28,671 | 6FFF | 0 | 0 | 1 | 1 | | 15 | 16,384 | 4000 | 32,767 | 7FFF | 0 | 1 | 0 | 0 | | | 20,480 | 5000 | 36,863 | 8FFF | 0 | 1 | 0 | 1 | | | 24,576 | 6000 | 40,959 | 9FFF | 0 | 1 | 1 | 0 | | | 28,672 | 7000 | 45,055 | AFFF | 0 | 1 | 1 | 1 | | 322 | 32,768 | 8000 | 49,151 | BFFF | 1 | 0 | 0 | 0 | | • | 36,864 | 9000 | 53,247 | CFFF | 1 | 0 | 0 | 1 | | | 40,960 | A000 | 57,343 | DFFF | 1 | 0 | 1 | 0 | | | 45,056 | B000 | 61,439 | EFFF | 1 | 0 | 1 | 1 | | | 49,152 | C000 | 65,535 | FFFF | 1 | 1 | 0 | 0 | | | 53,248 | D000 | 4,095 | ØFFF | 1 | 1 | 0 | 1 | | | 57,344 | E000 | 8,191 | 1FFF | 1 | 1 | 1 | 0 | | | 61,440 | F000 | 12,287 | 2FFF | 1 | 1 | 1 | 1 | <sup>0 =</sup> Switch open (or OFF - in down position - memory block inactive) Fig. 3-1. Page & Address Assignments for 48KRA-1 Selection Switches <sup>1 =</sup> Switch closed (or ON - in up position - memory block active) - 2) Find the desired starting address for the first page of the memory module in the field titled "STARTING ADDRESS." (Only the indicated starting addresses are available. No intermediate addresses can be used.) - 3) On the same horizontal line as the desired starting address, find the corresponding settings for the four switches A15, A14, A13, and A12 in the column titled "DIP SWITCH SETTINGS". - 4) On the memory module, find the group of four DIP switches associated with the first page. These are the first four in Switch 1. Refer to Fig 3-1, Page and Address Assignments for 48KRA-1 Selection Switches. Set the four switches to the selected pattern. - 5) In the same manner, set the 4 switches associated with each of the remaining pages. **EXAMPLE 1:** Note that each page takes up four 4K blocks. For continuous memory from 0000 to BFFF, the switch settings would be: | | Page 1 | Page 2 | Page 3 | |--------------|--------|--------|--------| | START. ADDR: | 0000 | 4000 | 8000 | | SETTINGS: | 0000 | 0100 | 1000 | EXAMPLE 2: For MINDRY at D000-FFFF and 0000-4FFF. Page 1 Page 2 Page 3 START. ADDR: D000 F000 1000 SETTINGS: 1101 1111 0001 Note that Page 1 covers both D000-FFFF and 0000-0FFF, and that Page 2 covers both F000-FFFF and 0000-2FFF. EXAMPLE 3: FOR MEMORY AT 0000-6FFF. Page 1 Page 2 Page 3 START. ADDR: 0000 3000 3000 SETTINGS: 0000 0011 0011 Note that is is permissible for a page to overlap part of another page, or a full page, and that the order of assignment is not important. You may change address switches with the board installed and power on. But to do this with a program running may crash the program. ### 3.3 INSTALLATION (Be sure you have read 2.0, Handling Precautions.) - 1) Turn OFF AC power to the host computer. - 2) If you are using a Sol computer, make sure it is jumpered for the standard 2.045 MHz clock rate. If you are using another computer, make sure its clock rate is 2.045 MHz or less. - 3) Discharge any possible static charge from your body. - 4) Be sure the address selection switches are set as desired. (Refer to the previous subsection 3.2, Setting Address Switches.) - 5) Orient the memory module to correspond with Fig 7-4, 48KRA-1 Assembly. (The legend should be in the readable position.) - 6) Find pin 1 on the computer S-100 bus connector. - 7) Orient the memory module edge-connector so that its own pin 1 will mate with pin 1 of the S-100 bus connector. On the component side of the board, edge-connector pin 1 is at the left end of the connector and pin 50 is at the right. Pins 51 through 100 are from left to right on the solder side (backside). ### **CAUTION** If the memory module is installed reversed, the memory module and/or computer could be damaged when power is applied. - 8) Slide the memory module into the card guides until its edge-connector just enters the bus connector. - 9) Gently push on the module until it is fully seated in the bus connector. ### 3.4 EXTENDED ADDRESSING AND 16-BIT DATA WORD OPTIONS Several options for extending addressing beyond 64K are provided for on the memory module. Because of the multiplicity of extended addressing schemes possible and presently used, only general guidelines for its implementation are given. The guidelines, together with the theory, are found in Section 5.6, Extended Addressing. A method for modifying the board to provide 16-bit data words is described in section 5.7. # **MEMORY TEST** ### 4.1 TEST BEFORE OPERATING Your 48KRA-1 memory module is fully inspected and tested before shipment to ensure that it is operating to specifications. It is packaged for safe transit under normal shipping conditions. Your memory module should, therefore, arrive in your hands ready for use. Nonetheless, we recommend that you test your 48KRA-1 before using it. This section describes the use of two memory tests: a short test and a "long" test. Actually, the difference in run time between the two tests is not significant. The size of the long test is 15F (hex); the short test is 4C (hex). It is recommended that you use the long version since it is more thorough and more useful for trouble-shooting. Your dealer will allow you to make a tape copy of the long test. If necessary, the short test can be keyed into the computer and used instead. The long test can be entered in an evening's work. Both these memory tests may also be used as diagnostic tools at any time after their initial use as pre-operating tests. ### NOTE The memory test programs are written for use with Processor Technology SOLOS or CUTER monitor programs. If you are not using either, you will need to modify the test programs to work with your monitor program. ### 4.2 THE RECOMMENDED PRE-OPERATING MEMORY TEST (A listing of the long memory test is in the Appendix.) In addition to testing your memory module, the long memory test prints out a complete map of the memory ICs as they are arranged on the board, marking bad ICs with an X. ## 4.2.1 Test Procedure (Long Memory Test) - 1) Obtain a copy of the test on cassette from your dealer. If you own a 48KRA-1, you may copy the program without violating the copyright. If you cannot obtain a copy, at the next step of this procedure, key in the program from the listing in the Appendix. Once in the computer, the program can be saved on tape for later use. - 2) Set the page assignment switches for continuous memory from 0 to 48K, referring to section 3.2, Setting Starting Addresses. Fig. 4-1. Page & Bit Assignments in 48KRA-1 Memory Array. 3) Load the long memory test into memory at C900 (hex). The Sol computer contains built-in system memory at the necessary locations. The program could be reassembled to run at a different address if necessary. 4) Type: EXEC C900 Press RETURN: The test displays a copyright notice and displays two options for selection by a key stroke: The test echoes "C" and repeats the test continuously, accumulating a record of errors. After each pass through the test, this option updates the test results, a map of ICs. Press any other key **Press C** The test echoes the key typed and runs one complete test cycle, displays the map of ICs, and returns control to SOLOS/CUTER. For the pre-operating memory test, select the C option. ### EXAMPLE OF ERROR MAP Reading left to right, top to bottom, each character in the map represents one of the 24 memory ICs, UI through U24. The characters are displayed in the same position as the memory ICS on the circuit board, when the board is oriented as in the assembly drawing, Fig 7-4. (For page and bit assignments in the memory array, refer to Fig. 4-1.) The example map above therefore shows that U9 made one or more errors during the test. Any memory IC reported as an "X" must be replaced. - 5) If the continuous test runs for 30 minutes with no "X" appearing, consider the memory module as having passed. - 6) To return control to SOLOS/CUTER at any time, press ESCAPE or UPPER CASE and REPEAT simultaneously. - 7) If you have keyed in the program by hand and it runs correctly, save it on cassette for later use, using the SOLOS/CUTER SAVE command. (Refer to SOLOS/CUTER User's Manual.) ### **4.3 SHORT MEMORY TEST** (Refer to the Appendix for the listing.) Use this short version only if the long version is not available. - 1) Set the page select switches for continuous memory from 0 through 48K. (Refer to 3.2, Setting Starting Addresses.) - 2) Load the program into memory at C900 (hex). The Sol computer contains built-in system memory at this location. The program could be reassembled to run at a different address if necessary. - 3) Type: EXEC C900 If no errors are encountered, the program repeats continuously. If the test runs for 30 minutes without the SOLOS/CUTER prompt appearing, consider the memory module to have passed the test. 4) Return control to SOLOS/CUTER by simultaneously pressing: UPPER CASE and REPEAT. - 5) If the SOLOS/CUTER prompt appeared while the test was running, the read data did not match the write data. An error report is stored in four locations of memory, which may be viewed as follows: - a. Enter the command: DU C949 C94C <CR>. The resulting display shows: Byte 1 and 2 The memory address where the error occurred. (Most significant byte first.) Byte 3 Correct Data. Byte 4 Erroneous Data. - b. If the most significant digit of the error address (in hex) is 1, 2, or 3, the error is in an IC in Page 1. - $\downarrow$ c. If it is 4, 5, 6, or 7, the error is in Page 2. - d. If it is 8, 9, A, or B, the error is in Page 3. - e. Determine the bad bit by comparing the correct and erroneous data stored in bytes 3 and 4 of the error report. - f. Knowing the bad bit and page, find the bad IC from Figure 4-1 and replace it. and took a south from 4-4 48KRA-1 # THEORY OF OPERATION ### **5.1 OVERVIEW** As you read this section refer to the block diagram, Figure 7-1 and the schematic, Figures 7-2 and 7-3. Note that the schematic is divided into two sheets which may be folded out in both directions, and that signals which go between the two sheets line up at the binding of the manual. The encircled numbers following the name of a functional block of circuitry described in this section correspond to the key numbers for the referenced block on the system block diagram, Fig. 7-1 and Table 7-1, Key to System Block Diagram. ### 5.1.1 S-100 Bus Interface The host computer and the 48KRA-1 communicate with one another over the S-100 Bus. Table 5-2, S-100 Bus Signals, identifies these signals and their sources and defines their functions. Table 5-3 briefly describes internal signals of the memory module. ### 5.1.2 Memory Array The memory array 2 consists of 24 16K dynamic memory ICs arranged in three rows of eight. Each dynamic RAM can store 16,384 bits. Each row of eight ICs stores 16,384 bytes. Each of the three rows is a page of memory. ### **5.1.3 Manufacturing Options** The memory module can support a wide variety of memory ICs which are 16-pin DIP ICs requiring +12 V, +5 V, and -5 V. Four pins are used for power supplies. One pin connects data-in and another connects data-out. Seven pins carry address information (14 bits in two samples). WE indicates whether to read or write, CAS provides timing, and RAS provides timing and selection. The memory module is designed to operate using a wide variety of memory ICs having various speeds. Any of a number of types may have been supplied with your module. Circuit variations required for the different memory ICs are provided in a variable 16-pin configuration module (A1) which plugs into a standard IC socket. ### 5.1.4 Dynamic Memory Refreshing Since the memory ICs used in the 48KRA-1 are dynamic memories in which the data cells operate by stored electrical charge which gradually dissipates, stored data must be restored periodically. Otherwise, current leakage would eventually change the stored data. The restoring process is called "refreshing" the memory, or simply "refresh." The 48KRA-1 itself provides memory refresh as required without any external intervention. In all cases it is done without introducing any delay to the CPU or DMA device controlling the module. ### 5.1.5 Addressing Assignment of the S-100 address lines are as follows: AØ-5 Row addressing. Column addressing. A7-A11 A12-A15 Page selection or 4K block selection. A6, A12 and A13 May be used for row or column, depending upon the type of memory IC. Address lines A12-A15 are compared to the three sets of four DIP switches to select one or none of three 16K memory arrays called "pages." Each page consists of one row of eight 16K RAM (Random Access Memory) ICs. Address lines AØ through A5 and A7 through A11 are applied to the Address Multiplexer (5) in two groups. These two groups are selected in succession to the memory address inputs. Row Address Strobe (RAS) is applied by the RAS Drivers (4) to the eight memory ICs of the selected page. The leading edge of RAS causes these eight ICs to store AØ-A5, the first group of address bits, called the row address, and to start a memory cycle. Subsequently, Column Address Strobe (CAS) (generated from the Bus Interface and Control logic 7) is applied to all of the memory ICs. The leading edge of CAS causes those memory ICs selected by RAS to store the second group, A7-A11, called the column address. Note that the column address section of the address multiplexer contains a Type D register which samples the S-100 lines at the same instant that RAS is causing the memory ICs to sample the ROW addresses. These latched address bits are subsequently moved to the memory ICs by CAS. ### 5.1.6 Write and Read Operations CAS samples Write Enable (WE) to determine whether the current cycle is to write data into memory or to read data from memory. The contents of the Data-Out Bus (DOØ-DO7) are applied to the MEM IN pins of the memory array by the Write Data register (1). This register is clocked at the rise of RAE with the start of each memory cycle. Each bit from the Data Out bus is applied to three memory ICs, one in each of the three pages. In a memory write operation, CAS causes the selected eight memory ICs to store the data found on their Data-In pins in an input latch. This data is subsequently stored at the location described by the row and column addresses. In a memory read operation, the selected eight memory ICs retrieve data from the memory address indicated by the row and column addresses, send it to their output latches, and enable their output drivers. At the end of RAS and CAS, the read data is latched into the output register (3), and is sent to the Data In Bus (DIØ-DI7) if EDO (Enable Data Output) is low. ### **5.2 PAGE SELECTION** Page selection and board selection depend on the address bits A12-A15 and on three quartets of switches. Each quartet of switches can be set to one of 16 possible starting addresses. Each quartet of switches corresponds to one page of eight memory ICs. The contents of each quartet of switches is compared to address bits A12-A15 by a ROM (Read Only Memory) in the Page Select Array (12) (U39 - U42). If a match is found, the output line from that ROM goes low. There are three such output lines, one per ROM, called MATCH lines. Each MATCH line corresponds to a page. A zero (low) on any MATCH line causes the PSEL (Page Select) lines of higher page number to be held high, thus only one page can be enabled (that with the lowest page number) even though more than one switch set may match A12-A15. This feature allows the memory module to be used in systems where less than its full memory extent is needed. During memory cycles, the three PSEL (Page Select) lines are selected by the Page Multiplexer 6 to drive the three PAGE lines. The PAGE lines select one or none of three RAS (Row Address Strobe) Drivers 4. Each RAS selects one of three pages in the memory array (2) ) ### **5.3 MEMORY CYCLES** (As defined in terms of the 48KRA-1, a cycle is a timed sequence of events that may perform one memory access.) # 5.3.1 Timing Scheme Enables Independent Refresh 48KRA-1 memory cycles correspond to S-100 bus T-cycles. This means that the memory module will not work in systems in which the PHASE 2 clock period is shorter than the minimum cycle period specified for the memory module: 489 ns. This allows a simple control logic design which does its needed refreshing totally independent of the S-100 bus and the CPU. There are no "coincidence" cycles in which the bus and the refresh logic contend for possession of the memory. There are no "wait" states, and the memory module does not use the ready lines # 5.3.2 Timing of Memory Cycles Located in the Bus Interface and Control Logic 7, the cycle timing circuitry consists of a latch and delay line driver, a delay line with five taps (U50) and a number of latches to provide the specific signals needed. When the S-100 bus clock, PHASE 2, goes low, a latch, RAE (U49-9), is set. The delay line input goes low. A negative step moves down the delay line. When it reaches the second tap, it resets the latch at the input end, and the delay line input rises. A positive step moves down the delay line. The fall of the next PHASE 2 starts another cycle. The delay line determines the specific durations of various features of a cycle. The timing of a typical read cycle is shown in Fig. 5-1. Fig. 5-1 Timing of Typical Read Cycle ) # 5.3.3 Types of Memory Cycles There are four types of memory module cycles: NULL, READ, WRITE, and REFRESH. Within the delay line all are identical. At the fall of PHASE 2, the state machine (part of the Bus Interface and Control logic (7)) considers its inputs and sets two outputs to new values. These two outputs, REFR and REN, partially determine the type of cycle. Later, two more outputs, WE and PEND, are set, completely determining the type of cycle. # **Null Cycle** A Null cycle is distinguished by REN (Row Enable) low. RAS and CAS do not occur. RAE (Row Address Enable) occurs but has no consequence. None of the memory ICs in the memory array do anything during a Null cycle. ### **Read Cycle** (Refer to Fig. 5-1, Timing of A Typical Read Cycle.) A Read cycle is distinguished by REN high, $\overline{\text{WE}}$ high, and REFR low. Just after PHASE 2 falls, REN occurs, enabling the three $\overline{\text{RAS}}$ drivers 4, and RAE rises causing the address multiplexers to present the row address to memory. $\overline{\text{RAC}}$ occurs, clocking the selected page into the $\overline{\text{RAS}}$ drivers. $\overline{\text{RAS}}$ occurs at the selected page of memory. ICs in that page of memory store the row address. CAE rises; the address multiplexers present the column address to the memory ICs. Soon $\overline{\text{CAS}}$ occurs. The memory ICs selected by $\overline{\text{RAS}}$ now store the column address, and set a bit to indicate that this is a read cycle. Then they get the data from the indicated address, and present it at their output pins. There is some variation among memory types in the details of how and when the outputs are enabled and the data is valid, but the output must be valid and enabled at the rise of DOC (Data Output Clock). At the end of the read cycle, REN is removed, ending RAS. The output data is clocked to the output register (3) at the rise of DOC. This data will be enabled to the DI bus if BSEL, ESEL and MSEL are all low, and SMEMR and PDBIN are both high. CAS rises at the fall of PHASE 2 with the start of the next cycle. Three ROM outputs (1 from each of three ROMs) in the Page Select Array (12) are connected together to form BSEL (Board Select). BSEL will be low if any page on the memory module is selected. ESEL (Extended Select), produced by the Extended Selection Logic (8), and MSEL produced by the Bus Interface and Control Logic, must also be low during a Read; SMEMR and PDBIN (both from a requesting processor on the S-100 bus) are both high. These are all used by the Bus Interface and Control Logic (7). The output EDO will be low enabling the tri-state outputs of the memory data output latch (3) to drive the DI Bus completing the Read operation when the board is selected. In the above cycles, memory ICs in the array, but not in the selected page, execute CAS-only cycles. Nothing of consequence happens in the memory module during these CAS-only cycles, but some types of memory ICs require these CAS-only cycles as part of their data output enabling scheme. # **Write Cycle** A Write cycle is distinguished by REN high, REFR low and WE low. Shortly after PHASE 2 falls, REN occurs enabling the four RAS drivers 4, and RAE rises, causing the address multiplexers to present the row address to memory, and clocking the data to be written into the Write Data Register 1. Next RAC occurs (U50-14), clocking the selected page into the RAS drivers. RAS occurs at the selected page of memory. ICs in that page of memory store the Row Address. Next, CAE rises, the Address Multiplexers 5 present the column address to the memory ICs. WE goes low, indicating a write cycle. Soon CAS occurs. The memory ICs selected by RAS now store the column address, a bit to indicate that this is a write cycle, and the data to be written from the Data In pins. At the end of the cycle, RAS and WE are removed. Before the removal of $\overline{\text{CAS}}$ , some data, not necessarily that just stored, is set into the output latch 3. This is not valid data and is not read because it does not get enabled onto the DI bus, since PDBIN is low at U36 keeping $\overline{\text{EDO}}$ high. $\overline{\text{CAS}}$ rises at the fall of PHASE 2 which starts the next cycle. ### Refresh Cycle A Refresh cycle is distinguished by the state machine in the Bus Interface and Control Logic 7 outputs, WE, REN and REFR high. REFR causes the Address Multiplexer 5 to present the address supplied by the Refresh Counter 10 to the memory ICs. REN occurs, enabling the four RAS drivers. RAC occurs, clocking the page number into the RAS drivers. RAS occurs at the selected page of memory. ICs in that page of memory store the refresh address as the row address, and in doing what they would normally do with it during a read, they refresh an entire row of memory within the active page. CAE occurs. This is of no consequence. CAS does not occur. At the end of the cycle, REN goes low, removing RAS. At the fall of PHASE 2 in the next cycle, REFR goes low, causing the refresh Counter 10 to count 1 and returning the Address Multiplexer outputs to the S-100 bus based row address. # 5.4 OPERATIONS: The State Machine 7 An operation is one or more cycles which are designed to achieve a desired result. An operation of the memory module is in response to a request from some other S-100 device. The memory module performs six types of operations: SELECTED READ, SELECTED WRITE, UNSELECTED READ and UNSELECTED WRITE, SELECTED DEPOSIT and UNSELECTED DEPOSIT. Figure 5-2, Sequences of the Operation Request Logic, shows a typical sequence of states for each of the six operation types. # 5.4.1 Variations of the Six Operations Each of these operations has many variations consisting of different sequences of possible states of the state machine. The state machine consists of an 8-input, 4-output ROM (U56) and four clocked latches. These variations are caused by two variables: - 1. The presence of T4, T5 and Tw cycles. - 2. The need for refresh. Operation request and sequencing is controlled by a state machine. Table 5-1, Sequences of the Operation of the State Machine, shows the possible states of this state machine expressed in terms of the ROM inputs and outputs. The state machine changes its outputs REFR and REN at the fall of PHASE 2. It changes its output $\overline{\text{WE}}$ at the fall of REN. It changes its output PEND at the rise of $\overline{\text{RAC}}$ . Each of the 14 possible states are variations of one of the four types of memory cycles: Null, Write, Refresh and Read. (Refer to 5.3.3, Types of Memory Cycles.) 1) Table 5-1. The States of The State Machine | | | | CONDITIONS TO ENTER CYCLE | | | | | OUTPUT DATA<br>LATCHED<br>DURING CYCLE | | | | HEXA.<br>OUT | | | | | |-------------------|---------|-----------|---------------------------|------|--------|--------|------|----------------------------------------|--------|--------|---|--------------|-----|--------|--------|--------| | CYCLE | | STATE | BSEL | MSEL | SWO | WRR | PEND | PSYNC | DEP | RFRQ | | UPEND | DWE | DREN | DREFR | | | READ | 1 | READ | - | - | - | Х | × | 1 | Х | х | | - | 0 | 1 | 0 | - | | | 1P | | X | - | 1 | X | × | 1 | Х | Х | L | 0 | 0 | 1 | 0 | 2 | | READ | 2<br>2P | UWP READ | - 1 | - | -<br>0 | X | × | 1 | X<br>X | X<br>X | 1 | -<br>0 | 0 | 1 | 0<br>0 | -<br>2 | | READ | 3<br>3P | SWP READ | - 0 | - | -<br>0 | X<br>X | × | 1 1 | X<br>X | X | | -<br>1 | 0 | 1<br>1 | 0<br>0 | -<br>A | | NULL | 4 | SWP NULL | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 0 | | 1 | 0 | 0 | 0 | 8 | | REFRESH | 5 | SWP REFR | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | | 1 | 0 | 1 | 1 | В | | NULL | 6 | UWP NULL | А | Α | 0 | 1 | 1 | 0 | 0 | 0 | | 0 | 0 | 0 | 0 | 0 | | REFRESH | 7 | UWP REFR | Α | Α | 0 | 1 | 1 | 0 | 0 | 1 | | 0 | 0 | 1 | 1 | 3 | | WRITE | 8 | SW WRITE | 0 | 0 | 0 | 0 | 1 | 0 | 0 | Х | | 0 | 1 | 1 | 0 | 6 | | READ | 9 | UW READ | А | Α | 0 | О | 1 | 0 | 0 | X | | 0 | 0 | 1 | 0 | 2 | | NULL | 10 | NULL | × | X | X | Χ | 0 | 0 | 0 | 0 | | 0 | 0 | 0 | 0 | 0 | | REFRESH | 11 | REFRESH | Х | Χ | X | Χ | 0 | 0 | 0 | 1 | | 0 | 0 | 1 | 1 | 3 | | WRITE | 12 | DEP WRITE | 0 | 0 | X | 1 | 0 | 0 | 1 | Х | | 1 | 1 | 1 | 0 | E | | READ | 13 | DEP READ | 0 | 0 | X | 1 | 1 | 0 | 1 | Х | | 0 | 0 | 1 | 0 | 2 | | READ | 14 | UDEP READ | Α | Α | Х | 1 | Х | 0 | 1 | Х | | 0 | 0 | 1 | 0 | 2 | | TIME FROM FALL OF | | | 70-0 | -126 | 0-85 | 350 | 150 | 0-300 | 350 | 350 | | 150 | 100 | 0 | 0 | | PHASE 2 (ns) 1 = SIGNAL HIGH 0 = SIGNAL LOW A = EITHER/BOTH A's HIGH X = DON'T CARE - = NOT READY YET ### **5.5 REQUESTS FOR MEMORY OPERATIONS** Three requests are possible: 1. Normal access SYNC high, MESEL, BSEL, ESEL, all low. Normal access has higher priority than Deposit. They will not normally occur at the same time. 2. Deposit DEP high, SYNC low. MSEL, BSEL, ESEL, all low. 3. Refresh request REFR low. Refresh request has low priority. It will cause a refresh if both the other requests are absent. ### 5.5.1 Normal Access, Selected Normal access, selected, and SWO high cause a Read state followed by a Refresh state or a Null state. Normal access, selected, and SWO low cause a WP READ followed by a Selected Write, followed by a Refresh or a Null state. Normal access, unselected, and SWO high cause a read state followed by a Refresh state or a Null state. Normal access, unselected, and SWO low cause a UW (Unselected Write) Read state followed by a Refresh state or a Null state. ### 5.5.2 Deposit ### Description Deposit results from the use of the front panel Deposit switch while the system is in a continuous train of Tw states usually showing showing a fetch status. The deposit pulse (MWRITE and not $\overline{PWR}$ ) is several T-cycles long. The first of these results in a Dep Write, the second results in a Dep Read so that the data just written will appear on the DI bus and the front panel data lights. The third will be a Null or a Refresh state. This sequence of three states will happen repeatedly. Eventually MWRITE will go away, causing a return to the normal Default or Refresh condition. ### Front Panels Which Use Deposit The memory module is intended to perform deposits for front panels or similar devices which meet the following description. S-100 front panels normally have a run-stop switch which stops the processor in an indefinite series of Tw states, showing a fetch status. When switched to stop, PHASE 1 and PHASE 2 clocks continue to be present. All other bus signals are stationary. Lights normally display the 16 address bits and the eight DO bits. The address may be changed by operating a switch called EXAMINE. This causes the processor to resume operation for three cycles by forcing the DI lines to correspond to the command JUMP; the front panel tricks the processor into believing that the fetch which was being held incomplete by Tw states was really a JUMP. The processor now reads two consecutive bytes which the front panel supplies from its address switches. Next the processor places these two bytes on the address bus and starts another fetch (from that address.) The front panel stops this fetch with another indefinite series of Tw states. The addressed memory location puts the requested data on the DI bus. The front panel displays the new address (which corresponds to its switches) and the new data. ## **How the Memory Module Produces Deposit** (Refer to Fig. 5-3, States of the Synchronous Counter Producing DEPOSIT.) To produce front panel deposit, the memory module uses a synchronous counter (U47). If MWRITE is present and $\overline{PWR}$ is absent, the counter produces a signal called DEP. DEP changes at about 350 ns after the trailing edge of PHASE 2. It will be high for two periods and low for one. This pattern will repeat until DEPOSIT is removed. The first period of DEP (count of E) produces a write cycle (DEP WRITE). The second period of DEP (count of F) produces a read cycle (DEP READ). The third period, DEP low (count of 0), produces a Refresh if one is requested. # Requirements for the Signal DEPOSIT DEPOSIT must produce MWRITE. DEPOSIT must not produce PWR. If synchronous, DEPOSIT must be stable at the clock 350 ns after the falling edge of PHASE 2. If asynchronous, DEPOSIT must be longer than one PHASE 2 period. There is no upper limit to the length of DEPOSIT. DEPOSIT is typically not synchronous to the clocks and is of varying length. The memory module synchronizes Deposit and assures that a long DEPOSIT pulse does not prevent timely refresh. No part of the system may produce MWRITE without PWR unless a deposit sequence is an acceptable result. (DMA DEVICES should produce PWR). WR is the processor's write strobe. PWR is WR applied to the S-100 bus. A DEPOSIT switch on the front panel produces a pulse which requests the contents of the DO lines (the contents of the front panel data switches) to be written to the memory location indicated by the address lines. The DEPOSIT pulse is normally ORed with PWR to produce MWRITE which is the write strobe used by memory. The memory module is expected to do the indicated storage in response to MWRITE. It is also expected to place the stored result on the DI bus so that it may appear on the front panel data lights confirming the results to the operator. With most dynamic RAMs this requires a read cycle after the write cycle; thus the memory board must distinguish between MWRITE due to $\overline{PWR}$ (normal processor write) and MWRITE due to Deposit. ## 5.5.3 Refresh The refresh request counter (of the Bus Interface and Control Logic 7) is a 74LS163 (U44). It counts PHASE 2 cycles. The terminal carry is used to produce RFRQ (Refresh Request) which is used by the state machine to request a refresh. REFR goes high when the refresh actually occurs. The clock at the end of terminal carry loads the counter to the complement of the required count. This preset number is established by the manufacturing optional configuration module 9 which varies with the memory ICs used. A CMOS 4040 provides a 9-bit Refresh Counter (10) (U43) which counts on the trailing edge of Refresh. The low order six outputs, R0-R5, deliver a refresh row address to the Address Multiplexer. R6 is optionally used for row or column address or page selection. R7 is used for page selection; R8 is used optionally for page selection. Their use depends upon the requirements of the memory ICs used. This selection is established by the optional configuration module (A1). IF IN LOAD ZONE, STATE ON NEXT CLOCK WILL BE: | l | F PWR HIGH | IF PWR LOW | |----------------|------------|------------| | IF MWRITE HIGH | E | Ø | | IF MWRITE LOW | 6 | | If E, then F, then Ø. Or, if PWR, then Ø. MWRITE • PWR produces two periods of DEP followed by one period of DEP. Fig. 5-3. States of the Synchronous Counter Producing DEPOSIT. ### **5.6 EXTENDED ADDRESSING** ### 5.6.1 Types of Extended Addressing The 8080 and most other microprocessors used in S-100 bus systems are able to address a memory space of 2 to the 16th power addresses (about 65 thousand). There are a number of methods in use or proposed which extend the memory addressing capability beyond 2 to the 16th. This is often described as "bank selection." The 48KRA-1 memory module is equipped with optional circuitry which will accommodate many different extended addressing methods. Once the details of the particular method are known, it is implemented by installing wires, ICs, and component carriers in the empty locations at the lower right corner of the board. This circuitry is referred to as Extended Selection Logic (8) in the block diagram, Fig. 7-1. Extended addressing methods which can be supported by the memory module can be classified by the methods by which the extended address is supplied to the memory board: - 1) The extended address is supplied on a group of S-100 lines assigned to this purpose. - A. The extended address is "encoded," i.e., it consists of a number less than 2<sup>n</sup> represented by the 2<sup>n</sup> combinations of the n signals. # 5.6.3 Modification Guidelines for Extended Selection Logic (Refer to Fig. 7-4, 48KRA-1 Assembly, for references to Areas A through D and lettered jumper pads.) ### **How to Produce ESEL** In the standard memory module $\overline{\text{ESEL}}$ is driven by an inverter (U55-6). The input of the inverter (U55-5) is held at +5 V by R9. The output holds $\overline{\text{ESEL}}$ low and the module is always enabled. Several simple two-bank and one of n-bank schemes can be implemented using this inverter and the option pads at its input and output. If the inverter input is to be wired to an S-100 line, R9 should be removed to avoid loading the S-100 line unnecessarily. For most extended addressing methods you will need to cut the trace between ESEL and U55-6 (Area B, pads 2 and 3) and install a jumper connecting ESEL to U65-9, 10, 11 or 12, (Area C, pads 1, 2, 3 and 4) and install a device in socket U65. (Refer to Areas B and C on the 48KRA-1 Assembly, Fig. 7-4.) For most methods the device installed in U65 will be a programmed PROM. For some simple methods, a component carrier with wire jumpers may suffice. U65 will normally be a 74S287 or 74S387. These are fusible link programmable read only memories. They have eight inputs, two disables, and four outputs. Each output can be programmed (permanently) to produce any function of eight input variables, controlled on an on-or-off basis by two more variables, the disables. Only one output will normally be needed. The other three can be left unprogrammed for later use, or can be programmed with alternate patterns to minimize the number of varieties of ROMs needed. The desired pattern is selected by the output jumper connecting U65, pads 9, 10, 11 or 12 to ESEL (Areas B and C). The 74S287 has 3-state outputs. The 74S387 has open collector outputs. If a pullup resistor is needed, install a jumper between $\overline{\text{ESEL}}$ and R9 near U55. (Refer to the 48KRA-1 Assembly, Fig. 7-4, Area B, pins 1 to 2.) ### Wiring the Address Inputs to U65 The eight inputs of U65 must receive the extended address. These may be connected in one of several ways: - 1. From an octal latch (74LS374) installed in U67, via jumpers on a component carrier installed in U66. - 2. From the "Extended Address," a set of eight S-100 lines via jumpers on a component carrier installed in U64. - 3. Via wire jumpers from any other points which may be appropriate. - 4. Any combination of the above. The octal latch, if used, takes its data from the DO Bus at the rising edge of its clock, XADC (Extended Address Clock). XADC is jumper-optioned to nine sources at the lower right corner of the board. (Refer to the assembly drawing, Fig. 7-4, Area D.) The first option is to the signal PSYNC • PHASE 2. If this option is used, extended address will be captured from the S-100 DO Bus just after the PHASE 2 fall during PSYNC. How the extended address gets put on the DO Bus at this time is a problem which must be solved externally to the memory module. The remaining eight options are the eight outputs of a 74LS138 which may be installed at U68. If one of these eight is chosen, the extended address will be latched from the DO Bus at the leading (falling) edge of PWR during an OUTPUT operation to the selected port. The port number (eight bits, PØ - P7) is specified as follows: | PORT BIT | FROM S-100 BIT | SPECIFIED BY | |----------|------------------|------------------------------------------------------| | PØ | A8 ) | | | P1 | A9 } | Selection of one of eight options at U65 outputs. | | P2 | A10 <sup>J</sup> | | | Р3 | A11 | Selection of All or All to U68-5 by jumper. (Area B) | | P4 | A12) | | | P5 | A13 | Decoded at U40 Pin 10 by program in PROM. | | P6 | A14 <b>(</b> | | | P7 | A15) | | ## **Modifying U40** A PROM is required in U40 to decode the high order four bits of the port address. The memory module may be manufactured containing PROMs at U40 inappropriate to this use. You may, therefore, need to substitute a different PROM at U40-10. Notice that the octal latch used, a 74LS374, is specified by most suppliers to sink 24 mA. This IC is suitable for use as an S-100 bus driver. Thus, one memory module equipped with the latch may be wired to drive the S-100 "Extended Address" bus of up to eight wires, and serve as the memory controller for other memory boards. It also may be used as an output port for any other purpose if not needed for extended addressing. ### Disable Inputs to U65 The PROM which generates ESEL, has two DISABLE inputs. One of these is driven by PROM U40-9. The other by U39-9. These two PROMS can be programmed so that response by the memory module can be controlled by any one function of S-100 addresses A12-A15 and switches S2, sections 1, 2, 3, 4 and also by any one function of S-100 addresses A12-A15 and switches S2, sections 5, 6, 7 and 8. In implementing extended addressing, you may need PROMs for U39 and U40 other than those found on a stock memory module. These disable controls are provided so that extended address selection can be governed in block sizes down to 4K, selectable by manual switch. The DISABLE inputs of U65 (Pins 13 and 14) can be jumpered to ØV (enabled) and the lines from U39-11 and U40-11 can be jumpered to the A6 and A7 inputs for a more versatile control with only six extended address bits. ### Timing of ESEL The eight inputs and two disables of U65 may be driven by virtually any signals which meet certain timing requirements. **ESEL** must not change while it is being used by the memory module. The rules describing the **ESEL** timing constraints are summarized as follows: - 1. ESEL may change at the falling edge of PHASE 2 during PSYNC. - 2. ESEL may change at the falling edge of PWR when SOUT is high. - 3. ESEL may change at any time that the S-100 Address may change. # 5.7 MODIFICATION FOR 16-BIT DATA WORDS (Refer to Fig. 7-4, 48KRA-1 Assembly, for lettered option areas.) Option Area A provides pads which may be useful in S-100 systems which extend or alter the normal data configuration. The original S-100 configuration provided a DI bus (DATA IN to the CPU) and a DO bus (DATA OUT from the CPU), both eight bits. These are tied together into a single 8-bit data bus in the SoI. The memory module can be modified to provide bits 8-15 so that two memory modules provide 16-bit wide memory for S-100 bus systems. This can be done by defining an additional set of eight lines to be DATA 8-15, and jumpering the memory module's input and output lines together to these pins in Area A and cutting the connections to the DO and DI S-100 pins. Alternately it can be done by re-defining the DO and DI sets as DØ-7 and D8-15 and making the appropriate cuts and jumpers. For systems which wish to mix 16-bit and 8-bit memory or input/output devices, the signals SXTRQ (Sixteen Request), S-100 pin 59, and SXTN (Sixteen Acknowledge), S-100 pin 61 may be provided by adding jumpers AB and CD. (Refer to Fig. 7-4, 48KRA-1 Assembly.) Note that these pin assignments are in conflict with the DATA 8-15 assignments. Table 5-2. S-100 Bus Signals of the 48KRA-1 Memory Module | SIGNAL | PIN | SOURCE | FUNCTION | |------------|-----|---------------------------------------------------|-----------------------------------------------------------------------------------------------------------| | AØ-A5 | * | Processor | Row address for memory. | | A7-A11 | * | Processor | Column address for memory. | | A6, 12, 13 | * | Processor | Row or column address depending on memory IC type. | | A12-15 | * | Processor | Page and 4K block selection. | | A16-23 | * | Processor or<br>Extended<br>Address<br>Controller | Extended address lines. | | DIØ-7 | * | Memory | (Data In) Read data lines. | | DOØ-7 | * | Processor | (Data Out) Write data lines. | | D8-15 | * | Any | Extended read data lines. | | MWRITE | 68 | Computer | (Memory Write) Write-strobe to memory. | | PDBIN | 78 | Processor | (Processor Data Bus In) Indirectly enables DI bus drivers during read. | | PHANTOM | 67 | Computer | Disables memory (optional) during power-on initialization program. | | PHASE 2 | 24 | Computer | Clocks Bus Interface and Control Logic (7). | | PSYNC | 76 | Processor | (Processor Sync) Controls requests for memory operations. | | PWR ( | 77 | Processor | (Processor Write) High during front panel deposit. Low during processor-controlled write. | | SINP | 46 | Processor | (Status Input) Disables certain operations of the Bus Interface, and Control logic $\widehat{7}$ . | | SMEMR | 47 | Processor | (Status Memory Read) Indirectly enables DI bus drivers 3. | | SOUT | 45 | Processor | (Status Output) Disables certain operations of the Bus Interface and Control Logic. | | SWO | 97 | Processor | (Status Write Out) Controls requests for read or write operations of the Bus Interface and Control Logic. | | SXTN | 61 | Memory | (Sixteen Acknowledge) Extended data signal used in systems which mix 8- and 16-bit S-100 cards. | | SXTRQ | 59 | Computer | (Sixteen Request) Extended data signal used in systems which mix 8- and 16-bit S-100 cards. | <sup>\*</sup>See Fig. 7-2 and 7-3, 48KRA Schematic, for pin number assignments. Table 5-3. Internal Signals of the 48KRA-1 Memory Module BSEL (Board Select) Input to state machine. CAS (Column Address Strobe) Drives all memory ICs, providing timing. DOC Data Output Clock) Clocks data to the output register (3). EDO (Enable Data Output) ESEL (Extended Select) Enable from Extended Selection Logic (8). MEM OUT $\emptyset$ -7 (Memory Output) lines of the memory array. MSEL (Memory Selected) Signal of the Bus Interface and Control Logic (7). A0-6 MUX (Multiplexed Address) Outputs of the Address Multiplexer (5). PEND (Cycle Pending) Output at the State Machine (7). PSEL (Page Select) RAC (Row Address Clock) Clocks the RAS drivers (4), and the column address register (7). RA DECODER (Refresh Address Decoder) RAE (Row Address Enable) when high, causes the address multiplexers (5) to present the row address. Clocks the write data registerr (1). RAS1 - RAS4 The four Row Address Strobe lines to the four pages of memory ICs. One or none of these will be active in any one cycle, providing timing and selection to pages. REFR (REFResh) State machine output which specifies refresh (when high). REN (Row ENable) State machine output which Enables the RAS drivers. RFRQ (Refresh Request) Refresh counter output. WE (Write Enable) Output of the state machine which specifies a write cycle (when low), a read cycle when high. WRR (WR Reclocked) Output of the Deposit counter. This signal is produced by reclocking PWR, an S-100 bus signal. XADC (Extended Address Clock) Signal produced by the Extended Selection Logic (8) governing latching of the extended address from the DO bus. # MAINTENANCE AND DIAGNOSTICS ### 6.1 SERVICE Should you encounter a problem in using the memory module, first consult the manual for a possible solution. If you are still unable to solve the problem or if you have subsequent failures which you cannot service yourself, ask your dealer for help. Service on all Processor Technology equipment, in or out of warranty, is the responsibility of the selling dealer. # **6.2 REPLACEMENT PARTS** Order replacement parts by Processor Technology part number, quantity and complete description (e.g., 6.8 ohm, 1/2 watt, 5% resistor). Your dealer may have a limited selection of replacement parts on hand. Certain standard parts may be available from electronic parts suppliers. ### 6.3 TROUBLESHOOTING AND DIAGNOSTIC TEST PROGRAMS The "long" memory test used in Section 4, Memory Test, may be used for trouble-shooting the memory modules and for periodic testing to assure system reliability. ### **6.4 HARDWARE TROUBLESHOOTING** Fig. 7-5, 48KRA-1 PCB traces, can be useful in signal-path tracing. This figure shows the traces on both sides of the PCB as viewed from the component side, but without the components obscuring the traces. # SECTION 7 # **DRAWINGS** | Fig. 7-1. | 48KRA-1 System Block Diagram | |-----------|------------------------------| | Fig. 7-2. | 48KRA-1 Schematic, Sheet 1 | | Fig. 7-3. | 48KRA-1 Schematic, Sheet 2 | | Fig. 7-4. | 48KRA-1 Assembly | | Fig. 7-5. | 48KRA-1 PCB Traces | Table 7-1. Key to System Block Diagram (The encircled key numbers refer to matching numbers on Fig. 7-1, 48KRA-1 System Block Diagram. For ICs represented and other details, refer to Fig. 7-2 and 7-3, 48KRA-1 Schematic.) | KEY # | NAME OF FUNCTIONAL BLOCK | ICs REPRESENTED | |-------------|---------------------------------|--------------------------------------| | 1 | Write Data Register | U61 | | 2 | Memory Array | U1 through 24 | | 3 | Output Register/Drivers | U62, 63 | | 4 | RAS Drivers | U35, U41 | | <b>(5</b> ) | Address Multiplexer | U42, U51-U53 | | 6 | Page Multiplexer | U33 | | 7 | Bus Interface and Control Logic | U36 (partially)<br>U44, 46-50, 55-59 | | 8 | Extended Selection Logic | U60, U64-U68 | | 9 | Configuration Module | A1 | | 10 | Refresh Counter | U43 | | 11) | Refresh Page Decoder | U36 | | 12 | Page Select Array and Switches | U34, U37 through<br>U39; S1, S2 | | 13 | Refresh Timer | U44 | Fig. 7-1. 48KRA-1 System Block Diagram Fig. 7-3. 48KRA-1 Schematic (Sheet 2) Copyright (C) 1978, by Processor Technology Corporation All rights reserved. #### NOTE: Both these patterns are viewed from the component side. The component side is the screened pattern. The solid pattern is the trace side. Fig. 7-5. 48KRA-1 PCB Traces (TA 214001D) 2, à K-1. S Cosmby Cost APPENDIX 1 # LONG MEMORY TEST PROGRAM (Listing) | | 0000 * | | | | |---------------|--------------------|-------------|------------|------------------------------------| | C900 | 0001 | ORG | 0C900H | | | | 0002 | XEQ | OCO04H | | | | 0003 | LST | | | | | | ROCESSO | R TECHNO | OLOGY 48KRA-1 TEST *** | | | 0005 * | | | | | | 0006 * | COI | PYRIGHT | (C) 1978, by | | | 0007 * | | | Technology Corporation | | | <b>*</b> 8000 | Al. | l right; | reserved. | | | 0009 * | | | | | C900 | 0010 BEGIN | | \$ | **** SETUP I/O **** | | C900 2E 04 | 0011 | MVI | L,04H | | | C902 22 53 CB | 0012 | SHLD | RTRN1 | FOR RETURN TO SOLOS/CUTER | | C905 2E 19 | 0013 | MVI | L,19H | | | C907 22 56 CB | 0014 | SHLD | SOUT1 | FOR SOLOS/CUTER OUTPUT | | C90A 2E 1F | 0015 | | L,1FH | | | C90C 22 59 CB | 0016 | SHLD | SINP1 | FOR SOLOS/CUTER INPUT | | | 0017 * | NOUNCE E | | • | | | 0018 *** ANI | NOUNCE | LEST *** | | | C90F 21 7D CA | 0019 <b>*</b> 0020 | TVT | II MOC 1 | MEGGACE ADDRESS | | C912 CD E5 C9 | 0020 | LXI<br>CALL | STRNG | MESSAGE ADDRESS<br>DISPLAY MESSAGE | | 0912 00 13 09 | 0021 | CALL | DIVING | DISPLAT MESSAGE | | | | ኮ ሮብእነጥፕ እ | וו פווסווג | R SINGLE PASS MODE | | | 0024 * | CONTI | 10005 01 | I SINGLE FASS MODE | | C915 AF | 0025 | XRA | A | SET PASS CONTROL | | C916 32 5B CB | 0026 | STA | CFLAG | FOR 1 PASS | | C919 CD F7 C9 | 0027 | CALL | GET | GO WAIT FOR A KEY | | C91C FE 43 | 0028 | CPI | 101 | CONTINUOUS MODE ? | | C91E C2 28 C9 | 0029 | JNZ | INIT | NOPE. | | 0,12 02 20 0, | 0030 * | 0112 | 11/11 | 101 L. | | C921 F5 | 0031 | PUSH | PSW | SAVE KEY | | C922 3E FF | 0032 | MVI | A,OFFH | | | C924 32 5B CB | 0033 | STA | CFLAG | RAISE FLAG | | C927 F1 | 0034 | POP | PSW | RESTORE KEY | | • | 0035 * | | | | | C928 | 0036 INIT | EQU | \$ | **** INITIALIZATION **** | | C928 CD FO C9 | 0037 | CALL | PUT | ECHO KEY | | C92B CD 00 CA | 0038 | CALL | CRLF | 20.0 1.21 | | 2 | 0039 * | <b>-</b> | <b>-</b> | | | C92E 21 00 00 | 0040 | LXI | н,О | CLEAR ERROR LOG | | C931 22 5E CB | 0041 | SHLD | ROW1 | | | C934 22 60 CB | 0042 | SHLD | ROW2 | | | C937 22 5C CB | 0043 | SHLD | BDADR | TEST BOARD AT ADRS. 0 | | | 0044 * | | | | | C93A | C93A<br>21 37<br>CD E5<br>97 | | 0045<br>0046<br>0047<br>0048 | CONT | EQU<br>LXI<br>CALL<br>SUB | | CONTINUOUS MODE LOOPS HERE<br>IN PROGRESS MESSAGE | |----------------|------------------------------|------------|------------------------------|-------|---------------------------|--------------|---------------------------------------------------| | | 32 62<br>32 63 | | 0049<br>0050<br>0051 | * | STA<br>STA | PAGE<br>FILL | PAGE NUMBER = 0<br>STATIC FILLER = 0 | | | C947<br>3A 63<br>07 | СВ | 0052<br>0053<br>0054 | MAIN | EQU<br>LDA<br>RLC | • | **** MAIN **** GET STATIC FILLER | | C94B | CD 39 | CA | 0055<br>0056 | * | CALL | WRITE | FILL ONE PAGE | | C94E | | | 0057 | | SUB | Α | MASTER PATTERN = ONE BIT | | C94F | | | 0058<br>0059 | | STC | • | IN NINE SET TO ONE. | | | C950 | | | LOOP1 | EQU | \$ | **** LOOP 1 **** | | C950 | | | 0061 | | PUSH | PSW | SAVE MASTER PATTERN | | | CD OB | CA | 0062 | | CALL | | GO PAST STATIC TEST PAGE | | | 1E 02 | | 0063<br>0064 | | MVI | E,2 | TWO PAGES REMAIN | | | C956<br>CD 2F | CA | 0066 | TEST1 | EQU | \$ | **** TEST 1 **** | | C959 | | CA | 0067 | | CALL<br>DCR | TEST<br>E | TEST NEXT PAGE REMAINING PAGES TESTED ? | | | C2 56 | Ca | 0068 | | JNZ | TEST1 | NO, DO NEXT ONE | | | | | 0069 | # | | | • | | | 3A 63 | СВ | 0070 | | LDA | FILL | ELSE CHECK | | C960 | CD 52 | CA | 0071 | | RLC | • DEAD | STATIC TEST PAGE | | | | CA | 0072<br>0073 | # | CALL | READ | FOR DROPPED BITS. | | C964 :<br>C965 | | | 0074 | | POP | PSW | RESTORE MASTER PATTERN | | | D2 50 | CO | 0075<br>0076 | | RAR | 100D1 | PERMUTE | | 6900 | טב טט | 69 | 0070 | * | JNC | LOOP1 | REPEAT EIGHT MORE TIMES | | C969 | BF | | 0078 | | CMP | Α | INVERT BITS OF | | C96A | | | 0079 | | MVI | | MASTER PATTERN | | | 0060 | | 0800 | | | | | | | C96C | | | LOOP2 | EQU | \$<br>DOL: | **** LOOP 2 **** | | C96C . | CD OB | CA | 0082<br>0083 | | PUSH<br>CALL | PSW | SAVE MASTER PATTERN | | C90D | | CA | 0084 | | MVI | NXTPG | SKIP PAST STATIC TEST PAGE | | 0910 | 15 02 | | 0085 | * | PIV I | E,2 | TWO PAGES REMAIN | | ( | C972 | | | TEST2 | EQU | \$ | | | | CD 2F | CA | 0087 | 12012 | CALL | TEST | TEST NEXT PAGE | | C975 | | | 0088 | | DCR | E | REMAINING PAGES TESTED ? | | | C2 72 | C9 | 0089 | | JNZ | TEST2 | NO, DO NEXT ONE | | | | | 0090 | * | | | , | | | 3A 63 | CB | 0091 | | LDA | FILL | ELSE CHECK STATIC | | C97C | | | 0092 | | RLC | | TEST PAGE | | C97D | CD 52 | CA | 0093 | | CALL | READ | FOR DROPPED BITS. | | 0000 | 0.4 | | 0094 | * | 202 | | | | C980 I | | | 0095 | | POP | PSW | RESTORE MASTER PATTERN | | C981 | DA 6C | CO | 0096 | | RAR | | PERMUTE | | 0902 | DA OC | U <b>y</b> | 0097<br>0098 | * | JC | LOOP2 | REPEAT EIGHT MORE TIMES | | | | | | | | | | | C985 CD OB CA | 0099 | CALL | NXTPG | REPEAT ENTIRE TEST | |---------------|------------|-------|-------------|------------------------------------------------| | C988 3A 62 CB | 0100 | LDA | PAGE | STARTING WITH | | C98B B7 | 0101 | ORA | Α | NEXT PAGE IF WE HAVEN'T | | C98C C2 47 C9 | 0102 | JNZ | MAIN | BEEN AROUND 3 TIMES ALREADY. | | | 0103 * | | | | | C98F 3A 63 CB | 0104 | LDA | FILL | INVERT FILLER | | C992 2F | 0105 | CMA | | THY DATE I I I I I I I I I I I I I I I I I I I | | C993 32 63 CB | 0106 | STA | FILL | AND TEST AGAIN | | C996 B7 | 0107 | ORA | | | | C997 C2 47 C9 | 0108 | | A<br>MA TAY | UNLESS ALREADY DONE. | | 0991 02 41 09 | 0109 * | JNZ | MAIN | | | C99A CD A7 C9 | | 7.140 | MA D | OVERNITE COURS AND | | CAR CD AL CA | 0110 | CALL | MAP | OUTPUT CHIP MAP | | 000D 24 ED 05 | 0111 * | | | | | C99D 3A 5B CB | 0112 | LDA | CFLAG | CONTINUOUS MODE ? | | C9A0 B7 | 0113 | ORA | Α | | | C9A1 CA 52 CB | 0114 | JZ | RTRN | NO. RETURN TO SOLOS/CUTER | | C9A4 C3 3A C9 | | JMP | CONT | YES. GO AROUND AGAIN | | | 0116 * | | | | | | 0117 * | *** 5 | SUBROUTI | NES **** | | | 0118 * | | | | | C9A7 | 0119 MAP | EQU | \$ | **** MAP **** | | C9A7 CD 00 CA | 0120 | - | CRLF | • • • • • • • • • • • • • • • • • • • • | | C9AA 2A 5E CB | 0121 | | ROW1 | PAGE 1 & 2 RESULTS | | C9AD CD BB C9 | 0122 | CALL | LINE | DISPLAY PAGE 1 | | C9B0 6C | 0123 | MOV | L,H | DISTEMI THOU | | C9B1 CD BB C9 | 0124 | CALL | LINE | DISPLAY PAGE 2 | | | 0125 * | Onde | PINL | DISTERT TRUE Z | | C9B4 2A 60 CB | 0126 | LHLD | ROW2 | PAGE 3 RESULTS | | C9B7 CD BB C9 | | CALL | LINE | | | C9BA C9 | 0128 | | | DISPLAY PAGE 3 | | CJDR CJ | 0129 * | RET | • | MAP COMPLETE | | C9BB | 0130 LINE | POII | | XXXX T TATES XXXX | | C9BB 16 04 | | - | \$ | | | C9DD 10 04 | 0131 | MVI | D,4 | # OF BIT PAIRS | | CORD 7D | 0132 * | | | | | C9BD 7D | 0133 PAIR | | A,L | | | C9BE 1F | 0134 | RAR | • | CARRY MEANS CHIP HAD ERRORS | | C9BF 6F | 0135 | MOV | L,A | REMAINING BITS GO BACK | | C9C0 CD D9 C9 | 0136 | CALL | CHIP | DISPLAY FIRST BIT OF PAIR | | 0000 00 | 0137 * | | | | | C9C3 7D | 0138 | MOV | A,L | A=RESULTS | | C9C4 1F | 0139 | RAR | • | TEST BIT, CARRY IS N.G. | | C9C5 6F | 0140 | MOV | L,A | RETURN THE REST | | C9C6 CD D9 C9 | 0141 | CALL | CHIP | DISPLAY 2ND. BIT OF PAIR | | | 0142 * | | | | | C9C9 CD D4 C9 | 0143 | CALL | SPAC1 | FOR READABILITY | | C9CC 15 | 0144 | DCR | D | LINE DONE? | | C9CD C2 BD C9 | 0145 | JNZ | PAIR | NO | | | 0146 * | | | | | C9DO CD OO CA | 0147 | CALL | CRLF | LINE IS DONE | | C9D3 C9 | 0148 | RET | • | RETURN | | | 0149 * | | | | | C9D4 | 0150 SPAC1 | EQU | \$ | **** SPACE **** | | C9D4 3E 20 | 0151 | MVI | • | WRITE A SPACE | | C9D6 C3 E0 C9 | 0152 | JMP | MARK1 | <del></del> | | - | 0153 * | | | | | | | | | | | C9D9<br>C9D9 3E 47<br>C9DB D2 E0 C9<br>C9DE 3E 58 | 0154 CHIP<br>0155<br>0156<br>0157<br>0158 * | EQU \$ MVI A,'G' JNC MARK1 MVI A,'X' | IT'S OK, ELSE | |---------------------------------------------------------------------------------------|----------------------------------------------------------------------|----------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------| | C9E0 CD F0 C9<br>C9E3 BF<br>C9E4 C9 | 0159 MARK1<br>0160<br>0161<br>0162 * | CALL PUT<br>CMP A<br>RET . | OUTPUT MARK<br>CLEAR CARRY BIT<br>RETURN | | C9E5<br>C9E5 7E<br>C9E6 23<br>C9E7 FE OO<br>C9E9 C8<br>C9EA CD FO C9<br>C9ED C3 E5 C9 | 0163 STRNG<br>0164<br>0165<br>0166<br>0167<br>0168<br>0169<br>0170 * | EQU \$ MOV A,M INX H CPI O RZ . CALL PUT JMP STRNG | **** STRING **** GET CHARACTER FROM STRING BUMP STRING POINTER IS IT END MARK ? YES, END OF STRING NO, OUTPUT CHARACTER CONTINUE | | C9F0<br>C9F0 E5<br>C9F1 47<br>C9F2 CD 55 CB<br>C9F5 E1<br>C9F6 C9 | 0171 PUT<br>0172<br>0173<br>0174<br>0175<br>0176 | EQU \$ PUSH H MOV B,A CALL SOUT POP H RET | **** OUTPUT ROUTINE **** SAVE IT CHAR. TO REG. B SOLOS/CUTER OUTPUT RESTORE IT | | C9F7<br>C9F7 CD 58 CB<br>C9FA CA F7 C9<br>C9FD E6 7F<br>C9FF C9 | 0178 GET<br>0179<br>0180<br>0181<br>0182<br>0183 * | EQU \$ CALL SINP JZ GET ANI 7FH RET | **** INPUT ROUTINE **** CHECK FOR CHAR. NONE YET NO PARITY! | | CAOO CAOO 3E OD CAOO CD FO C9 CAOS 3E OA CAO7 CD FO C9 CAOA C9 | 0184 CRLF<br>0185<br>0186<br>0187<br>0188<br>0189<br>0190 * | EQU \$ MVI A,ODH CALL PUT MVI A,OAH CALL PUT RET | **** DO CR AND LF **** DO CR DO LF | | CAOB CAOB F5 CAOC CD 58 CB CAOF FE 1B CA11 CA 52 CB | 0191 NXTPG<br>0192<br>0193<br>0194<br>0195<br>0196 * | EQU \$ PUSH PSW CALL SINP CPI 1BH JZ RTRN | | | CA14 3A 62 CB<br>CA17 C6 40<br>CA19 FE CO<br>CA1B C2 1F CA | 0197<br>0198<br>0199<br>0200<br>0201 <b>*</b><br>0202 | LDA PAGE ADI 40H CPI OCOH JNZ NXTP1 XRA A | PAST 3RD. PAGE ? | | CA1F 32 62 CB<br>CA22 F1<br>CA23 C9 | 0203 * 0204 NXTP1 0205 0206 0207 * | STA PAGE<br>POP PSW<br>RET . | SAVE | | CA25 3A 62 CB | CA24 F5 | 0209 | PUSH PSW | | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|-----------|-------------|----------------------| | CA2E 84 CA2E 67 CA2E 70 CA2E C9 CA2F | | | | | | CA2C 67 | | | | | | CA2D F1 | | | | | | CA2E C9 | | | | | | O216 * | | | | | | CA2F | CAZE C9 | | RET . | RETURN | | CA2F CD 39 CA | CAOE | | DOU A | | | CA32 CD 52 CA | | | | | | CA35 CD OB CA CA38 C9 CA39 CA36 CD 24 CA CA32 CA37 CA40 CA4 | | | | | | CA39 C9 | | | | | | O222 * | | | | | | CA39 | | | UEI . | THEN RETURN | | CA39 F5 CA37 CD 24 CA CA37 CD 24 CA CA37 CD 24 CA CA37 CD 24 CA CA37 CD 24 CA CA37 CD 225 CALL CA37 CD 24 CA CA37 CD 226 CA37 CD 247 CA37 CD 227 CA37 CD 228 WRIT1 CA37 CD 228 WRIT1 CA37 CD 228 WRIT1 CA37 CD 229 CA40 CT 7 CA40 CT 7 CA40 CT 7 CA40 CT 7 CA41 AE CA41 AE CA41 AE CA41 CC CA46 CA CA46 CT 7 CA41 CC CA46 CT | | | FOII & | **** UPTTF **** | | CA3A CD 24 CA | | | | | | CA3D 16 40 0227 * 0228 WRIT1 EQU \$ **** WRITE 1 **** CA3F F5 0229 PUSH PSW SAVE WORKING PATTERN CA40 77 0230 MOV M,A TRY TO STORE CA41 AE 0231 XRA M IS DATA GOOD? CA42 C4 6A CA 0232 CNZ BITER RECORD BIT IF NOT CA45 F1 0233 POP PSW RESTORE PATTERN CA46 17 0234 RAL . PERMUTE CA47 2C 0235 INR L BUMP STORAGE ADDRESS CA48 C2 3F CA 0236 JNZ WRIT1 CA48 C2 3F CA 0236 JNZ WRIT1 CA48 C4 15 0238 DCR D ENOUGH FOR 16K? CA40 C2 3F CA 0239 JNZ WRIT1 CA40 C2 3F CA 0239 JNZ WRIT1 CA50 F1 0240 POP PSW RESTORE CA51 C9 0241 RET . AND RETURN CA52 0243 READ EQU \$ **** READ **** CA52 0243 READ EQU \$ **** READ **** CA53 CD 24 CA 0245 CALL GETPG GET PROPER HL CA56 16 40 0246 MYI D,40H COUNT 16K CA58 0249 PUSH PSW SAVE CA58 0249 PUSH PSW SAVE WORKING PATTERN CA59 AE 0250 XRA M IS DATA STILL GOOD? CA50 F1 0252 POP PSW RESTORE PATTERN CA56 C4 6A CA 0251 CNZ BITER ACCUMULATE ERRORS CA56 C7 0254 INR L BUMP STORAGE ADDRESS CA50 F1 0252 POP PSW RESTORE CA50 F1 0253 RAL . PERMUTE CA51 C9 0249 PUSH PSW SAVE WORKING PATTERN CA52 CA52 NRA M IS DATA STILL GOOD? CA54 C4 6A CA 0251 CNZ BITER ACCUMULATE ERRORS CA56 C2 58 CA 0255 JNZ READ1 CA66 C2 58 CA 0255 JNZ READ1 CA66 F1 0259 POP PSW RESTORE CA60 C2 58 CA 0256 INR H BUMP STORAGE ADDRESS CA60 C2 58 CA 0255 JNZ READ1 CA64 F1 0259 POP PSW RESTORE CA64 C9 C9 0260 RET . AND RETURN CA64 C9 C9 0260 RET . AND RETURN | | | | | | CA3F | | | | | | CA3F F5 0229 PUSH PSW SAVE WORKING PATTERN CA40 77 0230 MOV M,A TRY TO STORE CA41 AE 0231 XRA M IS DATA GOOD? CA42 C4 6A CA 0232 CNZ BITER RECORD BIT IF NOT CA45 F1 0233 POP PSW RESTORE PATTERN CA46 17 0234 RAL . PERMUTE CA47 2C 0235 INR L BUMP STORAGE ADDRESS CA48 C2 3F CA 0236 JNZ WRIT1 CA4B 24 0237 INR H BUMP BY 256 EACH C45 F1 0240 POP PSW RESTORE CA50 F1 0240 POP PSW RESTORE CA50 F1 0240 POP PSW RESTORE CA51 C9 0241 RET . AND RETURN CA52 CA52 C5 C5 C5 C6 C6 C5 C5 C6 | 01192 10 10 | | 111 D, 1011 | COOKI TOK | | CA3F F5 | CA3F | | EQU \$ | **** WRTTE 1 **** | | CA40 77 CA41 AE CA41 AE CA42 C4 6A CA C231 XRA M CA45 F1 CA45 F1 CA46 17 CA46 17 CA46 17 CA47 CC CA47 CC CA47 CC CA47 CC CA48 C2 3F CA CA48 C2 3F CA CA40 C238 CA40 C238 CA40 C2 3F CA CA40 C240 CA50 F1 CA51 C9 CA52 CA52 CA52 CA52 CA52 CA53 CD 24 CA CA56 C6 CA58 CA56 C7 CA56 C7 CA56 C7 CA56 C7 CA57 CA57 CA58 CA58 CA58 CA58 CA58 CA58 CA58 CA58 | | | | | | CA41 AE | | | | | | CA42 C4 6A CA CA45 F1 CA46 17 CA46 17 CA47 CA46 17 CA47 CA46 17 CA47 CA47 CA46 17 CA47 CA47 CA47 CA47 CA47 CA48 CA48 CA48 CA48 CA48 CA48 CA48 CA48 | | _ | | | | CA45 F1 | | | | | | CA46 17 | | | | | | CA48 C2 3F CA | | | | | | CA4B 24 | | | | | | CA4C 15 | CA48 C2 3F CA | 0236 | JNZ WRIT1 | | | CA4D C2 3F CA | CA4B 24 | 0237 | | BUMP BY 256 | | CA50 F1 | CA4C 15 | 0238 | DCR D | ENOUGH FOR 16K ? | | CA50 F1 | CA4D C2 3F CA | 0239 | JNZ WRIT1 | NOPE | | CA52 | CA50 F1 | 0240 | POP PSW | RESTORE | | CA52 F5 0244 PUSH PSW SAVE CA53 CD 24 CA 0245 CALL GETPG GET PROPER HL CA56 16 40 0246 MVI D,40H COUNT 16K 0247 * CA58 0248 READ1 EQU \$ **** READ 1 **** CA58 F5 0249 PUSH PSW SAVE WORKING PATTERN CA59 AE 0250 XRA M IS DATA STILL GOOD ? CA5A C4 6A CA 0251 CNZ BITER ACCUMULATE ERRORS CA5D F1 0252 POP PSW RESTORE PATTERN CA5E 17 0253 RAL . PERMUTE CA5F 2C 0254 INR L BUMP STORAGE ADDRESS CA60 C2 58 CA 0255 JNZ READ1 CA63 24 0256 INR H BUMP BY 256 CA64 15 0257 DCR D ENOUGH FOR 16K ? CA65 C2 58 CA 0258 JNZ READ1 CA66 F1 0259 POP PSW RESTORE CA60 C9 0260 RET . AND RETURN CA6A 0262 BITER EQU \$ ***** BIT ERROR ***** CA6A 0263 BITER EQU \$ ***** BIT ERROR ***** CA6A E5 0263 PUSH H SAVE TEST ADDRESS | CA51 C9 | | RET . | AND RETURN | | CA52 F5 | | 0242 * | | | | CA53 CD 24 CA | CA52 | 0243 READ | EQU \$ | | | CA56 16 40 0247 * CA58 0248 READ1 EQU \$ **** READ 1 **** CA58 F5 0249 PUSH PSW SAVE WORKING PATTERN CA59 AE 0250 XRA M IS DATA STILL GOOD ? CA5A C4 6A CA 0251 CNZ BITER ACCUMULATE ERRORS CA5D F1 0252 POP PSW RESTORE PATTERN CA5E 17 0253 RAL . PERMUTE CA5F 2C 0254 INR L BUMP STORAGE ADDRESS CA60 C2 58 CA 0255 JNZ READ1 CA63 24 0256 INR H BUMP BY 256 CA64 15 0257 DCR D ENOUGH FOR 16K ? CA65 C2 58 CA 0258 JNZ READ1 CA68 F1 0259 POP PSW RESTORE CA69 C9 0260 RET . AND RETURN 0261 * CA6A 0262 BITER EQU \$ ***** BIT ERROR ***** CA6A E5 0263 PUSH H SAVE TEST ADDRESS | | 0244 | PUSH PSW | SAVE | | CA58 CA59 CA58 CA59 CA58 CA68 | | | | | | CA58 | CA56 16 40 | | MVI D,40H | COUNT 16K | | CA58 F5 0249 PUSH PSW SAVE WORKING PATTERN CA59 AE 0250 XRA M IS DATA STILL GOOD ? CA5A C4 6A CA 0251 CNZ BITER ACCUMULATE ERRORS CA5D F1 0252 POP PSW RESTORE PATTERN CA5E 17 0253 RAL . PERMUTE CA5F 2C 0254 INR L BUMP STORAGE ADDRESS CA60 C2 58 CA 0255 JNZ READ1 CA63 24 0256 INR H BUMP BY 256 CA64 15 0257 DCR D ENOUGH FOR 16K ? CA65 C2 58 CA 0258 JNZ READ1 CA66 F1 0259 POP PSW RESTORE CA69 C9 0260 RET . AND RETURN 0261 * CA6A 0262 BITER EQU \$ ***** BIT ERROR ***** CA6A E5 0263 PUSH H SAVE TEST ADDRESS | | | | | | CA59 AE 0250 XRA M IS DATA STILL GOOD ? CA5A C4 6A CA 0251 CNZ BITER ACCUMULATE ERRORS CA5D F1 0252 POP PSW RESTORE PATTERN CA5E 17 0253 RAL PERMUTE CA5F 2C 0254 INR L BUMP STORAGE ADDRESS CA60 C2 58 CA 0255 JNZ READ1 CA63 24 0256 INR H BUMP BY 256 CA64 15 0257 DCR D ENOUGH FOR 16K ? CA65 C2 58 CA 0258 JNZ READ1 CA68 F1 0259 POP PSW RESTORE CA69 C9 0260 RET AND RETURN 0261 * CA6A C5 0262 BITER EQU \$ ***** BIT ERROR ***** CA6A E5 0263 PUSH H SAVE TEST ADDRESS | <del>-</del> | | | | | CA5A C4 6A CA CA5D F1 CA5D F1 CA5E 17 CA5E 17 CA5E 17 CA5F 2C CA6O C2 58 CA C | | | | | | CA5D F1 0252 POP PSW RESTORE PATTERN CA5E 17 0253 RAL . PERMUTE CA5F 2C 0254 INR L BUMP STORAGE ADDRESS CA60 C2 58 CA 0255 JNZ READ1 CA63 24 0256 INR H BUMP BY 256 CA64 15 0257 DCR D ENOUGH FOR 16K ? CA65 C2 58 CA 0258 JNZ READ1 CA68 F1 0259 POP PSW RESTORE CA69 C9 0260 RET . AND RETURN 0261 * CA6A 0262 BITER EQU \$ ***** BIT ERROR ***** CA6A E5 0263 PUSH H SAVE TEST ADDRESS | | = | | | | CA5E 17 | | | | | | CA5F 2C 0254 INR L BUMP STORAGE ADDRESS CA60 C2 58 CA 0255 JNZ READ1 CA63 24 0256 INR H BUMP BY 256 CA64 15 0257 DCR D ENOUGH FOR 16K ? CA65 C2 58 CA 0258 JNZ READ1 CA68 F1 0259 POP PSW RESTORE CA69 C9 0260 RET AND RETURN 0261 * CA6A 0262 BITER EQU \$ ***** BIT ERROR ***** CA6A E5 0263 PUSH H SAVE TEST ADDRESS | | | | | | CA60 C2 58 CA | | | | | | CA63 24 0256 INR H BUMP BY 256 CA64 15 0257 DCR D ENOUGH FOR 16K? CA65 C2 58 CA 0258 JNZ READ1 CA68 F1 0259 POP PSW RESTORE CA69 C9 0260 RET . AND RETURN 0261 * CA6A 0262 BITER EQU \$ ***** BIT ERROR ***** CA6A E5 0263 PUSH H SAVE TEST ADDRESS | | | | BUMP STORAGE ADDRESS | | CA64 15 0257 DCR D ENOUGH FOR 16K ? CA65 C2 58 CA65 CA66 | | | | DUMP DV 056 | | CA65 C2 58 CA | _ | | | | | CA68 F1 0259 POP PSW RESTORE CA69 C9 0260 RET . AND RETURN 0261 * CA6A 0262 BITER EQU \$ **** BIT ERROR **** CA6A E5 0263 PUSH H SAVE TEST ADDRESS | | | | ENOUGH FUR TOK ? | | CA69 C9 | | | | DECTADE | | 0261 * CA6A 0262 BITER EQU \$ **** BIT ERROR **** CA6A E5 0263 PUSH H SAVE TEST ADDRESS | | | | | | CA6A 0262 BITER EQU \$ **** BIT ERROR **** CA6A E5 0263 PUSH H SAVE TEST ADDRESS | CRUJ CJ | | WET . | WAN VETOVA | | CAGA E5 0263 PUSH H SAVE TEST ADDRESS | CAAA | | EOU & | **** RTT FRROD **** | | | | | | | | | | | | | | CA6C 3A 62 CB CA6F 07 CA70 07 CA71 00 CA72 00 CA73 21 5E CB CA76 85 CA77 6F CA78 7E CA79 B0 CA7A 77 CA7B E1 CA7C C9 | 0265 * 0266 0267 0268 0269 0270 0271 * 0272 0273 0274 0275 0276 0277 0278 * 0279 0280 | LDA RLC RLC NOP NOP LXI ADD MOV ORA MOV POP RET | PAGE GET CURRENT PAGE . SHIFT TO . LOW ORDER . TWO BITS . H,BITS ERROR LOG ADDRESS L DISPLACE BY PAGE # L,A A,M GET ACCUMULATED ERRORS B ADD NEW ONES M,A AND PUT IN LOG H RESTORE TEST ADDRESS . AND RETURN TO TEST | |--------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------|-------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | CA7D OB CA7E 20 20 20 20 20 20 20 20 20 50 52 4F 43 45 53 53 4F 52 20 54 45 43 48 4E 4F 4C 4F 47 59 20 34 38 4B 52 41 2D 31 20 54 45 53 54 | 0281 <b>*</b><br>0282 MSG1<br>0283 | DB<br>ASC | OBH CLEAR SCREEN " PROCESSOR TECHNOLOGY 48KRA-1 TEST" | | CAA6 OD OA<br>CAA8 43 4F 50 59<br>52 49 47 48<br>.54 20 28 43<br>29 20 31 39<br>37 38 2C | 0284<br>0285 | DW<br>ASC | OAODH<br>"COPYRIGHT (C) 1978," | | CABB 20 50 52 4F<br>43 45 53 53<br>4F 52 20 54<br>45 43 48 4E<br>4F 4C 4F 47<br>59 20 43 4F<br>52 50 2E | 0286 | ASC | " PROCESSOR TECHNOLOGY CORP." | | CAD6 OD OA<br>CAD8 OD OA<br>CADA 54 59 50 45<br>20 27 43 27<br>20 54 4F 20<br>52 55 4E 20<br>43 4F 4E 54<br>49 4E 55 4F | 0287<br>0288<br>0289 | DW<br>DW<br>ASC | OAODH OAODH "TYPE 'C' TO RUN CONTINUOUSLY" | | 55 53 4C 59 CAF6 20 41 4E 44 20 41 43 43 55 4D 55 4C 41 54 45 20 45 52 52 4F 52 53 2E CBOD OD OA | 0290<br>0291 | ASC<br>DW | " AND ACCUMULATE ERRORS." OAODH | | ODOD OD OR | 0271 | <i>D</i> 11 | ····· | | CBOF 53 54 52 49 4B 45 20 41 4E 59 20 4F 54 48 45 52 20 4B 45 59 20 54 4F 20 52 55 4E 20 4F 4E 45 20 50 41 53 53 | 0292 ASC | "STRIKE ANY OTHER KEY TO RUN ONE PASS." | |------------------------------------------------------------------------------------------------------------------|--------------------------------|-------------------------------------------------| | 2E | | | | CB34 OD OA | 0293 DW | OAODH | | CB36 00 | 0294 DB<br>0295 # | 0 | | CB37 34 38 4B 52 | 0296 MSG2 ASC | "48KRA-1 TEST IN PROGRESS" | | 41 2D 31 20<br>54 45 53 54<br>20 49 4E 20<br>50 52 4F 47<br>52 45 53 53 | OZYO PISOZ RSC | TORRET TEST IN FROGRESS | | CB4F OD OA | 0297 DW | OAODH | | CB51 00 | 0298 DB | 0 | | | 0299 # | | | | 0300 *** VECTORS 7 | TO SOLOS/CUTER *** | | CDE 2 C2 | 0301 <b>*</b> | OCCUL THE OR CORE | | CB52 C3 | 0302 RTRN DB<br>0303 RTRN1 DS | OC3H JMP OP. CODE 2 RETURN ADDRESS GOES HERE | | CB53<br>CB55 C3 | 0303 RTRN1 DS<br>0304 SOUT DB | 2 RETURN ADDRESS GOES HERE OC3H JMP OP. CODE | | CB56 | 0305 SOUT1 DS | 2 OUTPUT ADDRESS GOES HERE | | CB58 C3 | 0306 SINP DB | OC3H JMP OP. CODE | | CB59 | 0307 SINP1 DS | 2 INPUT ADDRESS GOES HERE | | 0299 | 0308 * | t in or not | | | 0309 <b>*</b><br>0310 <b>*</b> | **** SCRATCH PAD AREA **** | | CB5B | 0311 CFLAG DS | 1 IF CONTINUOUS MODE = 0, ELSE 1 | | CB5C | 0312 BDADR DS | 2 TEST BOARD ADDRESS | | CB5E | 0313 BITS EQU | \$ ERROR MAP FOLLOWS | | CB5E | 0314 ROW1 DS | 2 ERROR LOG FOR TOP ROW | | CB60 | 0315 ROW2 DS | 2 ERROR LOG FOR BOTTOM ROW | | CB62 | 0316 PAGE DS | 1 CURRENT PAGE | | CB63 | 0317 FILL DS | 1 STATIC TEST BYTE | | | 0318 * | Dring 4 minor XXX | | | 0319 *** END OF 48 | SKRA-1 TEST *** | # APPENDIX 2 # **SHORT MEMORY TEST PROGRAM (Listing)** | C900 | | | <b></b> | | | | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|----------|-----------|----------------|------------|-----------------------------| | 0002 | cann | | | ORG | OCOOOH | | | 0003 ** 0004 ** 46KRA-1 SHORT MEMORY TEST ** 0005 * 0006 ** Copyright (C) 1978, by 0007 * Processor Technology Corporation 0008 * All rights reserved. C900 2E 04 0010 C902 22 47 C9 0011 SHLD RTRN FOR RETURN TO SOLOS/CUTER 0012 * C905 AF 0013 XRA A C906 37 0014 STC . CREATE MASTER PATTERN C907 F5 0015 PUSH PSW SAVE IT ON STACK C908 F5 0016 PUSH PSW AND A COPY TO WORK WITH 0017 * C909 21 00 00 0018 LOOP LXI H,0 FILL MEMORY FROM 0 TO BFFF C900 77 0021 MOV M,A TO MEMORY C900 17 0021 MOV M,A TO MEMORY C900 17 0022 RAL . NEW PATTERN C907 F5 0024 PUSH PSW BACK TO STACK C910 23 0026 INX H NEXT MEMORY ADDRESS C911 TC 0027 MOV A,H C912 FE CO 0028 CPI OCOH PAST BFFF ? C914 C2 0C C9 0029 JNZ WRITE NOT YET C916 F1 0031 POP PSW WORKING PATTERN C918 F1 0032 POP PSW WORKING PATTERN C918 F1 0032 POP PSW WORKING PATTERN C918 F1 0032 POP PSW WORKING PATTERN C918 F1 0032 POP PSW WORKING PATTERN C918 F1 0032 POP PSW MASTER PATTERN C918 F1 0032 POP PSW MASTER PATTERN C918 F1 0032 POP PSW BACK TO STACK C914 F5 0034 PUSH PSW BACK TO STACK C915 F5 0039 PUSH PSW THEN SAVE IT C926 BE 0040 CMP M DOES MEMORY MATCH ? C927 F1 0044 RAL . NEW WORKING PATTERN C928 F5 0045 POP PSW GET WORKING PATTERN C926 F5 0044 POP PSW GET WORKING PATTERN C927 POP PSW GET WORKING PATTERN C928 F5 0044 POP PSW GET WORKING PATTERN C926 F5 0045 POP PSW GET WORKING PATTERN C926 F5 0045 POP PSW GET WORKING PATTERN C926 F5 0044 RAL . NEW WORKING PATTERN C926 F5 0045 PUSH PSW BACK TO STACK C926 F5 0045 PUSH PSW BACK TO STACK C926 F5 0045 PUSH PSW BACK TO STACK C927 PUSH PSW BACK TO STACK C928 F5 0044 PUSH PSW BACK TO STACK C926 F5 0045 PUSH PSW BACK TO STACK C926 F5 0045 PUSH PSW BACK TO STACK C926 F5 0045 PUSH PSW BACK TO STACK C926 F5 0045 PUSH PSW BACK TO STACK C927 PUSH PSW BACK TO STACK C926 F5 DO45 PUSH PSW BACK TO STACK C926 F5 DO45 PUSH PSW BACK TO STACK C926 F5 DO45 PUSH PSW BACK TO STACK C926 F5 DO45 PUSH PSW BACK TO STACK C927 PUSH PSW BACK TO STACK C926 F5 DO45 PUSH PSW BACK TO STACK C946 PUSH PSW BACK TO STACK C947 PUSH PSW BACK TO STACK C947 PUSH P | 0,00 | | | | | | | 0004 ** 48KRA-1 SHORT MEMORY TEST ** 0005 * 0006 * 0007 * 0007 * 0007 * 0007 * 0008 * 0009 * 0009 * 0009 * 0009 * 0009 * 0009 * 0009 * 0009 * 0009 * 0009 * 0009 * 0009 * 0009 * 0009 * 0009 * 0009 * 0009 * 0009 * 0009 * 0009 * 0009 * 0009 * 0009 * 0001 | | | | | 0000 111 | | | O006 | | | 0004 ** 1 | 48KRA-1 SH | ORT MEMO | DRY TEST ** | | 0007 Processor Technology Corporation 0008 All rights reserved. 0009 X | | | | | ( <b>-</b> | 2 | | C900 2E 04 | | | | | | | | C900 2E 04 | | | | | | | | C900 2E 04 0010 MVI L,4 C902 22 47 C9 0011 SHLD RTRN FOR RETURN TO SOLOS/CUTER 0012 * C905 AF 0013 XRA A C906 37 0014 STC . CREATE MASTER PATTERN C907 F5 0015 PUSH PSW SAVE IT ON STACK C908 F5 0016 PUSH PSW AND A COPY TO WORK WITH 0017 * C909 21 00 00 0018 LOOP LXI H,0 FILL MEMORY FROM 0 TO BFFF C90C F1 0020 WRITE POP PSW GET WORKING PATTERN C90D 77 0021 MOV M,A TO MEMORY C90E 17 0023 RAL . NEW PATTERN C90F F5 0024 PUSH PSW BACK TO STACK C910 23 0026 INX H NEXT MEMORY ADDRESS C911 7C 0027 MOV A,H C912 FE C0 0028 CPI 0C0H PAST BFFF ? C914 C2 0C C9 0029 JNZ WRITE NOT YET C917 F1 0031 POP PSW WORKING PATTERN C918 F1 0032 POP PSW MASTER PATTERN C919 F5 0033 PUSH PSW BACK TO STACK C910 F5 0034 PUSH PSW BACK TO STACK C911 F5 0033 PUSH PSW BACK TO STACK C912 FE C0 0026 LXI H,0 CHECK FROM 0 TO BFFF C914 F5 0034 PUSH PSW BACK TO STACK C915 F5 0039 PUSH PSW THEN SAVE IT C916 F1 0036 READ1 POP PSW GET WORKING PATTERN C917 F1 0038 READ1 POP PSW GET WORKING PATTERN C918 F1 0038 READ1 POP PSW GET WORKING PATTERN C919 F5 0039 PUSH PSW THEN SAVE IT C920 BE 0040 CMP M DOES MEMORY MATCH ? C921 C2 36 C9 0041 JNZ ERROR NO. IT'S WRONG! C924 F1 0043 POP PSW GET WORKING PATTERN C925 F5 0045 PUSH PSW BACK TO STACK | | | | all rights | reserve | ea. | | C902 22 47 C9 | C900 2E | 04 | | MVT | т. Ц | | | C905 AF | | | | | | FOR RETURN TO SOLOS/CUTER | | C905 AF C906 37 C906 37 C907 F5 C907 F5 C908 F1 C909 C91 C908 C91 C909 C91 C908 C91 C908 F5 C91 C908 C91 C909 C91 C909 C91 C91 C91 C909 | 0,02 22 | ., 0) | | Dilib | 114 1114 | TON REPORT TO BOLLOD, COTEN | | C906 37 C907 F5 C908 C909 C91 C909 C91 C900 C90 C900 C91 C | C905 AF | | | XRA | A | | | C907 F5 C908 C909 21 00 00 C909 21 00 00 C909 C91 C900 | | | - | | •• | CREATE MASTER PATTERN | | C908 F5 | | | | | PSW | | | C909 21 00 00 | | | | | | | | C909 21 00 00 0018 LOOP | ., | | | | 10,, | mis it don't to work with | | C90C F1 | C909 21 | 00 00 | | I X.1 9 | н.О | FILL MEMORY FROM O TO BEFF | | C90C F1 C90D 77 0021 MOV M,A TO MEMORY 0022 * C90E 17 C90F F5 0024 PUSH PSW BACK TO STACK 0025 * C910 23 C911 7C C912 FE C0 C914 C2 OC C9 0029 JNZ C914 F1 0031 POP PSW MASTER PATTERN C918 F1 C918 F1 C918 F5 0034 PUSH PSW WORKING PATTERN C918 F1 C918 F5 0036 LXI H,O CHECK FROM O TO BFFF C916 F5 0039 PUSH PSW THEN SAVE IT C920 BE C924 F1 0043 POP PSW GET WORKING PATTERN C925 17 C945 F5 0044 POP PSW GET WORKING PATTERN C926 F5 O044 POP PSW GET WORKING PATTERN C918 F1 C926 F5 O041 D052 POP PSW GET WORKING PATTERN C918 F1 O036 LXI H,O CHECK FROM O TO BFFF C921 C2 36 C9 O041 JNZ ERROR NO. IT'S WRONG! C924 F1 O043 POP PSW GET WORKING PATTERN C925 17 O044 RAL NEW WORKING PATTERN PSW THEN SAVE IT C926 F5 O045 PUSH PSW GET WORKING PATTERN C926 F5 O045 PUSH PSW GET WORKING PATTERN NEW WORKING PATTERN NEW WORKING PATTERN C926 F5 O045 PUSH PSW GET WORKING PATTERN C926 F5 O045 PUSH PSW GET WORKING PATTERN NEW WORKING PATTERN C926 F5 O045 PUSH PSW GET WORKING PATTERN C926 F5 O045 PUSH PSW GET WORKING PATTERN C926 F5 O045 PUSH PSW BACK TO STACK | | | | | , - | | | C90D 77 | C90C F1 | | | TE POP | PSW | GET WORKING PATTERN | | C90E 17 | C90D 77 | | | | | | | C90E 17 C90F F5 O024 PUSH PSW BACK TO STACK 0025 ** C910 23 O026 INX H NEXT MEMORY ADDRESS C911 7C O027 MOV A,H C912 FE C0 O028 CPI OCOH PAST BFFF ? C914 C2 OC C9 O029 JNZ WRITE NOT YET C918 F1 O031 POP PSW WORKING PATTERN C918 F1 O032 POP PSW MASTER PATTERN C919 F5 O033 PUSH PSW BACK TO STACK C91A F5 O034 PUSH PSW AND A COPY TO WORK WITH C91B 21 00 00 O036 LXI H,O CHECK FROM O TO BFFF C91F F5 O039 PUSH PSW THEN SAVE IT C91F F5 O040 CMP M DOES MEMORY MATCH ? C920 BE O040 CMP M DOES MEMORY MATCH ? C921 C2 36 C9 O041 JNZ ERROR NO. IT'S WRONG! C924 F1 O043 POP PSW GET WORKING PATTERN C925 17 O044 RAL NEW WORKING PATTERN C926 F5 O045 PUSH PSW BACK TO STACK | | | | ••• | , | | | C90F F5 | C90E 17 | | | RAL | _ | NEW PATTERN | | C910 23 | | | | | PSW | | | C910 23 | | | | | | | | C911 7C | C910 23 | | | INX | Н | NEXT MEMORY ADDRESS | | C912 FE C0 | | | | | | | | C914 C2 OC C9 | C912 FE | CO | 0028 | CPI | | PAST BFFF ? | | C917 F1 | | | | | | | | C917 F1 | ` | - | | - | | | | C918 F1 | C917 F1 | | | POP | PSW | WORKING PATTERN | | C919 F5 C91A F5 O034 PUSH PSW AND A COPY TO WORK WITH O035 * C91B 21 00 00 O036 LXI H,0 CHECK FROM O TO BFFF O037 * C91E F1 O038 READ1 C91F F5 O039 PUSH PSW GET WORKING PATTERN C920 BE O040 CMP M DOES MEMORY MATCH ? C921 C2 36 C9 O041 JNZ ERROR NO. IT'S WRONG! O042 * C924 F1 O043 POP PSW GET WORKING PATTERN O042 * C925 17 O044 RAL NEW WORKING PATTERN O045 PUSH PSW BACK TO STACK | | | | | | | | C91A F5 O034 PUSH PSW AND A COPY TO WORK WITH O035 * C91B 21 00 00 O036 LXI H,O CHECK FROM O TO BFFF O037 * C91E F1 O038 READ1 POP PSW GET WORKING PATTERN C91F F5 O039 PUSH PSW THEN SAVE IT C920 BE O040 CMP M DOES MEMORY MATCH ? C921 C2 36 C9 O041 JNZ ERROR NO. IT'S WRONG! O042 * C924 F1 O043 POP PSW GET WORKING PATTERN C925 17 O044 RAL NEW WORKING PATTERN C926 F5 O045 PUSH PSW BACK TO STACK | | | _ | | | | | C91B 21 00 00 0036 LXI H,O CHECK FROM 0 TO BFFF 0037 * C91E F1 0038 READ1 POP PSW GET WORKING PATTERN C91F F5 0039 PUSH PSW THEN SAVE IT C920 BE 0040 CMP M DOES MEMORY MATCH ? C921 C2 36 C9 0041 JNZ ERROR NO. IT'S WRONG! 0042 * C924 F1 0043 POP PSW GET WORKING PATTERN C925 17 0044 RAL NEW WORKING PATTERN C926 F5 0045 PUSH PSW BACK TO STACK | C91A F5 | | | | - | | | C91B 21 00 00 0036 LXI H,O CHECK FROM O TO BFFF 0037 * C91E F1 0038 READ1 POP PSW GET WORKING PATTERN C91F F5 0039 PUSH PSW THEN SAVE IT C920 BE 0040 CMP M DOES MEMORY MATCH ? C921 C2 36 C9 0041 JNZ ERROR NO. IT'S WRONG! 0042 * C924 F1 0043 POP PSW GET WORKING PATTERN C925 17 0044 RAL NEW WORKING PATTERN C926 F5 0045 PUSH PSW BACK TO STACK | - | | _ | | | | | C91E F1 0038 READ1 POP PSW GET WORKING PATTERN C91F F5 0039 PUSH PSW THEN SAVE IT C920 BE 0040 CMP M DOES MEMORY MATCH? C921 C2 36 C9 0041 JNZ ERROR NO. IT'S WRONG! 0042 * C924 F1 0043 POP PSW GET WORKING PATTERN C925 17 0044 RAL . NEW WORKING PATTERN C926 F5 0045 PUSH PSW BACK TO STACK | C91B 21 | 00 00 | | I.X.I | н.о | CHECK FROM O TO BEFF | | C91E F1 | | | | | , - | | | C91F F5 0039 PUSH PSW THEN SAVE IT C920 BE 0040 CMP M DOES MEMORY MATCH? C921 C2 36 C9 0041 JNZ ERROR NO. IT'S WRONG! 0042 * C924 F1 0043 POP PSW GET WORKING PATTERN C925 17 0044 RAL . NEW WORKING PATTERN C926 F5 0045 PUSH PSW BACK TO STACK | C91E F1 | | | D1 POP | PSW | GET WORKING PATTERN | | C920 BE 0040 CMP M DOES MEMORY MATCH ? C921 C2 36 C9 0041 JNZ ERROR NO. IT'S WRONG! 0042 * C924 F1 0043 POP PSW GET WORKING PATTERN C925 17 0044 RAL . NEW WORKING PATTERN C926 F5 0045 PUSH PSW BACK TO STACK | | | | | | | | C921 C2 36 C9 0041 JNZ ERROR NO. IT'S WRONG! 0042 * C924 F1 0043 POP PSW GET WORKING PATTERN C925 17 0044 RAL . NEW WORKING PATTERN C926 F5 0045 PUSH PSW BACK TO STACK | | | | | | | | 0042 <b>*</b> C924 F1 0043 POP PSW GET WORKING PATTERN C925 17 0044 RAL . NEW WORKING PATTERN C926 F5 0045 PUSH PSW BACK TO STACK | | 36 C9 | | | | | | C924 F1 0043 POP PSW GET WORKING PATTERN C925 17 0044 RAL . NEW WORKING PATTERN C926 F5 0045 PUSH PSW BACK TO STACK | | <u>-</u> | | · <del>-</del> | | | | C925 17 0044 RAL . NEW WORKING PATTERN C926 F5 0045 PUSH PSW BACK TO STACK | C924 F1 | | | POP | PSW | GET WORKING PATTERN | | C926 F5 0045 PUSH PSW BACK TO STACK | - | | _ | | • | | | • • • • • • • • • • • • • • • • • • • • | | | | | PSW | | | | - <del>-</del> | | 0046 * | | | | | C927<br>C928 | | 0047<br>0048 | INX<br>MOV | Н<br>А,Н | NEXT MEMORY ADDRESS | |--------------|-----------|---------------|------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | FE CO | 0049 | CPI | осон | PAST BFFF ? | | | C2 1E C9 | 0050 | JNZ | READ1 | NOT YET | | | - | 0051 * | | | | | C92E | F1 | 0052 | POP | PSW | WORKING PATTERN | | C92F | F1 | 0053 | POP | PSW | MASTER PATTERN | | C930 | 17 | 0054 | RAL | • | NEW MASTER | | C931 | F5 | 0055 | PUSH | PSW | BACK TO STACK | | C932 | | 0056 | PUSH | PSW | AND A COPY TO WORK WITH | | C933 | C3 09 C9 | 0057 | JMP | LOOP | ON AND ON | | | | 0058 * | | | | | C936 | | 0059 ERROR | MOV | D,M | GET INCORRECT DATA | | C937 | | 0060 | MOV | E,A | AND WHAT IT SHOULD BE | | C938 | | 0061 | XCHG | | | | | 22 4B C9 | 0062 | SHLD | SAVE+2 | | | C93C | | 0063 | XCHG | • | GET ADDRESS OF ERROR | | C93D | | 0064 | VOM | D,H | | | C93E | | 0065 | MOA | H,L | PUT IN CORRECT ORDER | | C93F | | 0066 | VOM | L,D | | | C940 | 22 49 C9 | 0067 | SHLD | SAVE | TO REPORT AREA | | 00110 | 04 1/4 40 | 0068 * | | | | | | 2A 47 C9 | 0069 | LHLD | RTRN | GET SOLOS/CUTER RETURN ADDRESS | | C946 | E9 | 0070 | PCHL | • | GO THERE | | ao iu | | 0071 * | ~~ | | | | C947 | | 0072 RTRN | DS | 2 | | | | | 0073 <b>*</b> | י איבוני א | . העשה | TONE AND BUILD BORD BUILD BUIL | | | | 0074 * REPOR | AI AREA | | S ONE AND TWO ARE THE ADDRESS WHERE THE | | | | 0076 * | | EUROI | R OCCURED, MOST SIGNIFICANT BYTE FIRST. | | | | 0077 * | | מידעם | THREE IS THE CORRECT DATA. | | | | 0078 * | | DIIE | THREE IS THE CORRECT DATA. | | | | 0079 * | | BYTE | FOUR IS THE ERRONEOUS DATA. | | | | 0080 * | | DITE | FOUR IS THE ERRONEOUS DATA. | | | C949 | 0081 SAVE | EQU | \$ | | | | | 0082 * | _40 | Ψ | | | C949 | | 0083 | DS | 1 | BYTE ONE STORED HERE | | C94A | | 0084 | DS | 1 | BYTE TWO STORED HERE | | C94B | | 0085 | DS | 1 | BYTE THREE STORED HERE | | C94C | | 0086 | DS | 1 | BYTE FOUR STORED HERE | | | | 0087 * | | | | | | | | | | | # APPENDIX 3 # IC PIN CONFIGURATIONS (Top View) ## 7805, 7812, 7905 U PACKAGE (TO-220) | OUTPUT<br>VOLTAGE | ORDER<br>PART NO. | |-------------------|-------------------| | 5V | 7805CU/SA7805CU | | 6V | 7806CU/SA7806CU | | 8V | 7808CU/SA7808CU | | 12V | 7812CU/SA7812CU | | 13 8V | 7814CU/SA7814CU | | 15V | 7815CU/SA7815CU | | 18V | 7818CU/SA7818CU | | 24V | 7824CU/SA7824CU | #### 4040B ### general description The CD4020BM/CD4020BC, CD4060BM/CD4060BC are 14-stage ripple carry binary counters, and the CD4040BM/CD4040BC is a 12-stage ripple carry binary counter. The counters are advanced one count on the negative transition of each clock pulse. The counters are reset to the zero state by a logical "1" at the reset input independent of clock. #### 74SØØ QUADRUPLE 2-INPUT POSITIVE-NAND GATES 00 positive logic: $Y = \overline{AB}$ SN5400 (J) SN54H00 (J) SN54LS00 (J, W) SN7400 (J N) SN74H00 (J, N) SN74L00 (J, N) SN74LS00 (J, N) SN54S00 (J, W) SN74S00 (J, N) ## 74LSØ2 QUADRUPLE 2-INPUT POSITIVE-NOR GATES 02 positive logic: $Y = \overline{A+B}$ SN5402 (J) SN54L02 (J) SN54LS02 (J, W) SN54S02 (J, W) SN74L02 (J, N) SN74LS02 (J, N) SN74S02 (J, N) ### 74LSØ4 HEX INVERTERS 04 positive logic: $Y = \overline{A}$ SN5404 (J) SN54H04 (J) SN54LS04 (J, W) SN54S04 (J, W) SN7404 (J, N) SN74H04 (J, N) SN74L04 (J, N) SN74LS04 (J, N) SN74S04 (J, N) #### 74LS109 DUAL J-K POSITIVE-EDGE-TRIGGERED FLIP-FLOPS WITH PRESET AND CLEAR ### 109 FUNCTION TABLE | FUNCTION TABLE | | | | | | | | | |----------------|-------|-------|---|---|------------|------------------|--|--| | INPUTS | | | | | | OUTPUTS | | | | PRESET | CLEAR | CLOCK | J | ĸ | a | ā | | | | L | н | Х | X | Х | Н | L | | | | . н | L | x | Х | x | L | н | | | | L | L | x | X | X | н• | н• | | | | н | H | Ť | L | L | L | н | | | | н | H | t | н | L | TOGGLE | | | | | н | н | t | L | н | $\alpha_0$ | $\bar{\alpha}_0$ | | | | н | н | † | н | Н | н | L | | | | н | н | L | X | X | $\alpha_0$ | $\bar{\alpha}_0$ | | | SN54109 (J, W) SN74109 (J, N) SN54LS109A (J, W) SN74LS109A (J, N) #### 745112 DUAL J-K NEGATIVE-EDGE-TRIGGERED FLIP-FLOPS WITH PRESET AND CLEAR ## 112 | FUNCTION TABLE | | | | | | | | | | | |----------------|-------|-------|---|---|----------------|---------|--|--|--|--| | INPUTS | | | | | | OUTPUTS | | | | | | PRESET | CLEAR | CLOCK | J | K | a | ā | | | | | | L | н | × | × | х | н | L | | | | | | н | t. | × | × | × | L | н | | | | | | L | L | × | × | × | н• | н. | | | | | | H | н | | L | L | Q <sub>0</sub> | $a_0$ | | | | | | н | н | 1 | н | L | н | L | | | | | | н | н | | L | н | L | н | | | | | | н | н | | Н | н | TOGGLE | | | | | | | н | н | н | X | X | $ a_0 $ | $a_0$ | | | | | SN54LS112 (J, W) SN74LS112 (J, N SN54S112 (J, W) SN74S112 (J, N) ## 74LS126 QUADRUPLE BUS BUFFER GATES WITH THREE-STATE OUTPUTS #### 126 positive logic . Y = A Output is off (disabled) when C is low. SN54126 (J, W) SN74126 (J, N) SN54LS126 (J, W) SN74LS126 (J, N) # 74LS138 3-TO-8 LINE DECODERS/MULTIPLEXERS #### 138 SN54LS138 (J, W) SN74LS138 (J, N) SN54S138 (J, W) SN74S138 (J, N) #### 74LS139 DUAL 2-TO-4 LINE DECODERS/MULTIPLEXERS 139 SN54LS139 (J, W) SN74LS139 (J, N) SN54S 139 (J, W) SN74S139 (J, N) #### 74LS158 QUAD 2- TO 1-LINE DATA SELECTORS/MULTIPLEXERS 157 NONINVERTED DATA OUTPUTS 158 INVERTED DATA OUTPUTS #### 74LS163 SYNCHRONOUS 4-BIT COUNTERS 160 DECADE, DIRECT CLEAR 161 BINARY, DIRECT CLEAR 162 DECADE, SYNCHRONOUS CLEAR 163 BINARY, SYNCHRONOUS CLEAR #### 74LS173 4-BIT D-TYPE REGISTERS 173 3-STATE OUTPUTS #### 74LS244 OCTAL BUFFERS/LINE DRIVERS/LINE RECEIVERS 244 NONINVERTED 3-STATE OUTPUTS #### 74LS287, 74LS387 1024-BIT PROGRAMMABLE READ-ONLY MEMORIES 287 256 4-BIT WORDS 3-STATE OUTPUTS SN54157 (J, W) SN74157 (J, N) SN54L157 (J) SN74L157 (J, N) SN54LS157 (J, W) SN54S157 (J, W) SN54S158 (J, W) SN54S158 (J, W) SN54S158 (J, W) SN54S158 (J, W) SN54S158 (J, N) SN54160 (J, W) SN54LS160A (J, W) SN54LS161A (J, W) SN54LS161A (J, W) SN54LS162A (J, W) SN54LS162A (J, W) SN54LS163 (J, W) SN54LS163A (J, W) SN54LS163 (J, W) SN74160 (J, N) SN74LS160A (J, N) SN74LS161A (J, N) SN74LS161A (J, N) SN74LS162A (J, N) SN74LS162A (J, N) SN74LS163 (J, N) SN74LS163 (J, N) SN74LS163 (J, N) SN54173 (J, W) SN74173 (J, N) SN54LS173 (J, W) SN74LS173 (J, N) SN54LS244 (J) SN74LS244 (J, N) SN54S287 (J, W) SN74S287 (J, W)